【数据库实验一】数据库及数据库中表的建立实验

目录

实验1  学习RDBMS的使用和创建数据库

一、 实验目的

二、实验内容

三、实验环境

四、实验前准备

五、实验步骤

六、实验结果

七、评价分析及心得体会

实验2 定义表和数据库完整性

一、 实验目的

二、实验内容

三、实验环境

四、实验前准备

五、实验步骤

六、实验结果

七、评价分析及心得体会


实验1  学习RDBMS的使用和创建数据库

一、 实验目的

(1)熟悉某一RDBMS产品(如:SQL Server ) 的环境。

(2)掌握企业管理器的基本使用方法,对数据库及其对象有基本了解,了解对SQL Server 进行配置的方法。

(3)掌握查询分析器的基本使用方法以及在查询分析器中执行T-SQL语句的方法。

(4)了解SQL Server 数据库的逻辑结构和物理结构。

(5)学会在企业管理器中创建数据库及查看数据库属性。

(6)学会使用T-SQL语句创建数据库。

二、实验内容

(1)学会使用企业管理器和查询分析器管理工具。

(2)使用企业管理器创建数据库。

创建一个教务管理数据库,名称为JWGL,数据文件的初始大小为20MB,文件增长方式为自动增长,文件增长增量设为5MB,文件的增长上限为500MB。日志文件的初始大小为10MB,文件增长增量设为1MB,文件的增长限制设为100MB。数据文件的逻辑文件名和物理文件名均采用默认值,分别为JWGL_data和d:\Microsoft SQL Server\MSSQL\data\ JWGL_data.mdf;事务日志文件的逻辑文件名和物理文件名也采用默认值,分别为JWGL_log和d:\Microsoft SQL Server\MSSQL\data\JWGL_log.ldf。

(3)在查询分析器中使用T-SQL语句创建数据库。

创建一个名为Market的数据库(注意e盘下应存在sql_data目录)。

CREATE DATABASE Market

ON

   (NAME = Market_Data,

    FILENAME = 'e:\sql_data\Market_Data.mdf',

    SIZE = 10,

    MAXSIZE = 50,

    FILEGROWTH = 10%)

LOG ON

    (NAME = Market_Log,

    FILENAME = 'e:\sql_data\ Market__Log.ldf',

    SIZE = 5,

    MAXSIZE = 15,

    FILEGROWTH = 10%);    

(4)使用T-SQL语句或企业管理器创建一个图书借阅管理数据库,数据库名为TSGL,数据文件和日志文件的初始大小、增长方式、文件的增长上限等均可采用默认值。

(5)使用T-SQL语句或企业管理器创建第2章习题10的SPJ数据库,可以自行定义文件大小、增长方式等。

(6)查看物理磁盘目录,理解并分析SQL Server 数据库的存储结构。

(7)使用企业管理器查看数据库属性。

(8)使用T-SQL语句或企业管理器对于(2)~(5)中建立的数据库进行修改和删除操作,并进一步查看物理磁盘目录。

三、实验环境

mysql-8.3.0-win64

MySQL Workbench 8.0 CE

四、实验前准备

下载并安装MySQL以及MySQL Workbench

五、实验步骤

可以使用Create a new scheme

使用语句

其他的均相同

六、实验结果

七、评价分析及心得体会

通过此次实验,我熟悉了MySQL Workbench的环境,掌握了企业管理器的基本使用方法,对数据库及其对象有基本了解,学会在企业管理器中创建数据库及查看数据库属性,学会使用MySQL语句创建数据库,并了解数据库的逻辑结构和物理结构。

实验2 定义表和数据库完整性

一、 实验目的

(1)了解SQL Server 的基本数据类型、空值的概念,以及表的结构特点。

(2)学会使用T-SQL语句和企业管理器创建表结构和修改表结构。

(3)学会使用SQL Server 提供的数据完整性功能,并在创建表时定义表的数据完整性。通过实验进一步理解数据完整性的概念及分类。

二、实验内容

(1)用企业管理器在教务管理数据库JWGL中创建学生表Student、课程表Course、学生选课表SC,它们的表结构如表B.1所示。

(2)用T-SQL语句在Market数据库中创建客户基本信息表Customers、货品信息表Goods、订单信息表Orders,它们的定义如下

 CREATE TABLE Customers(

         CustomerID  int  IDENTITY(1,1)  PRIMARY  KEY,

         CName  varchar(8)  NOT  NULL ,

         Address  varchar(50),

         City  varchar(10),

         Tel  varchar(20)  UNIQUE,

         Company  varchar(50),

         Birthday  datetime,

         Type  tinyint  DEFAULT 1);

CREATE TABLE Goods (

         GoodsID int  CONSTRAINT  C1 PRIMARY  KEY ,

         GoodsName  varchar(20)  NOT  NULL,

         Price  money,

         Description  varchar(200),

         Storage   int,

         Provider  varchar(50),

         Status  tinyint  DEFAULT(0));

CREATE TABLE Orders (

         OrderID  int  IDENTITY(1,1)  CONSTRAINT  C2  PRIMARY  KEY ,

         GoodsID  int  NOT NULL  REFERENCES Goods(GoodsID)  ON  DELETE

             CASCADE,

         CustomerID  int  NOT NULL  FOREIGN KEY(CustomerID)

             REFERENCES Customers (CustomerID)  ON  UPDATE  CASCADE

ON DELETE NO ACTION,

         Quantity  int  NOT NULL  CONSTRAINT  C3  CHECK(Quantity >0),

         OrderSum  money  NOT NULL,

         OrderDate  datetime  DEFAULT(getdate()) );

(3)使用T-SQL语句在SPJ数据库中创建第2章习题6中的4张表:供应商表S、零件表P、工程项目表J和供应情况表SPJ,数据类型和长度自行设计,注意要同时定义主键、外键和其他的数据完整性。

(4)使用T-SQL语句在图书借阅管理数据库TSGL中建立图书、读者和借阅3个表,其结构为

图书(书号,书名,类别,出版社,作者,定价,出版时间)

读者(借书证号,姓名,单位,性别,地址,电话号码)

借阅(书号,借书证号,借阅日期)

要求为属性选择合适的数据类型,定义每个主键、外键,是否允许空值等数据完整性约束。

三、实验环境

mysql-8.3.0-win64

MySQL Workbench 8.0 CE

四、实验前准备

复习创建表的语句

五、实验步骤

(1)可以通过Create Table进行建表

(2)也可以用MySQL语句实现

student、course、sc

customers、goods、orders

s、p、j、spj

图书、读者、借阅

CREATE TABLE jwgl.student (Sno CHAR(8) NOT NULL,Sname VARCHAR(10) NOT NULL ,Sex CHAR(2) NOT NULL DEFAULT '男' CHECK (Sex='男' or Sex='女'),Age TINYINT(1) NOT NULL DEFAULT 20 CHECK (Age BETWEEN 15 AND 30),Phonenumber CHAR(12) NULL UNIQUE,Sdept VARCHAR(20) NOT NULL,PRIMARY KEY (`Sno`));CREATE TABLE jwgl.course (Cno CHAR(10) NOT NULL,Cname VARCHAR(20) NOT NULL UNIQUE,Total_perior TINYINT UNSIGNED NOT NULL DEFAULT 64 CHECK (Total_perior BETWEEN 32 AND 108),Week_perior TINYINT UNSIGNED NOT NULL DEFAULT 4 CHECK (Week_perior BETWEEN 2 AND 7),credit TINYINT UNSIGNED NOT NULL DEFAULT 4 CHECK (credit BETWEEN 1 AND 7),Pcno CHAR(10),PRIMARY KEY (Cno)
);
CREATE TABLE jwgl.sc (Sno CHAR(8) NOT NULL,Cno CHAR(10) NOT NULL,Grade TINYINT(1) NULL CHECK (Grade BETWEEN 0 AND 100), PRIMARY KEY (Sno, Cno),FOREIGN KEY (Sno) REFERENCES Student(Sno),FOREIGN KEY (Cno) REFERENCES Course(Cno)
);create table market.customers (CustomerID int not null auto_increment,CName varchar(8) not null,Address varchar(50),City varchar(10),Tel varchar(20) unique,Company varchar(50),Bithday date,Type tinyint default 1,primary key (CustomerID)
);create table market.goods (GoodsID int not null,GoodsName varchar(20) not null,Price decimal(10,2),Description varchar(200),Storage int,Provider varchar(50),Status tinyint default 0,primary key(GoodsID)
);create table market.orders(OrderID int not null auto_increment,GoodsID int not null,CustomerID int not null,Queantity int not null check ( Queantity>0),OrderSum decimal(10,2) not null,OrderDate datetime default  (now()),primary key (OrderID),foreign key( GoodsID) references goods(GoodsID) on delete cascade,foreign key(CustomerID) references customers(CustomerID) on update cascade on delete no action
);create table spj.s(SNO CHAR(2) PRIMARY KEY,SNAME VARCHAR(50),STATUS INT,CITY VARCHAR(50)
);create table spj.p(PNO char(2) primary key,PNAME varchar(50),COLOR varchar(20),WEIGHT float);create table spj.j(JNO char(2) primary key,JNAME varchar(50),CITY varchar(50));create table spj.spj(SNO char(2),PNO char(2),JNO char(2),QTY int,primary key(SNO,PNO,JNO),foreign key(SNO) references s(SNO),foreign key(PNO) references p(PNO),foreign key(JNO) references j(JNO));create table `tsgl`.`图书`(`书号` char(13) primary key,`书名` varchar(255) not null,`类别` varchar(50),`出版社` varchar(100),`作者` varchar(100),`定价` decimal(10,2),`出版时间` date
);create table `tsgl`.`读者`(`借书证号` char(10) primary key,`姓名` varchar(50) not null,`单位` varchar(100),`性别` enum('男','女') not null,`地址` varchar(255),`电话号码` varchar(20)
);CREATE TABLE `tsgl`.`借阅` (`书号` CHAR(13),`借书证号` CHAR(10),`借阅日期` DATE,PRIMARY KEY (`书号`, `借书证号`),FOREIGN KEY (`书号`) REFERENCES `图书`(`书号`) ON DELETE CASCADE ON UPDATE CASCADE,FOREIGN KEY (`借书证号`) REFERENCES `读者`(`借书证号`) ON DELETE CASCADE ON UPDATE CASCADE
);

六、实验结果

七、评价分析及心得体会

在本次实验中,我了解MySQL的基本数据类型、空值的概念,以及表的结构特点。并学会使用MySQL语句和企业管理器创建表结构和修改表结构。使用SQL Workbench提供的数据完整性功能,并在创建表时定义表的数据完整性,通过实验进一步理解数据完整性的概念及分类。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/467251.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot健身房管理:技术与实践

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统,它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等,非常…

CulturalBench :一个旨在评估大型语言模型在全球不同文化背景下知识掌握情况的基准测试数据集

2024-10-04,为了提升大型语言模型在不同文化背景下的实用性,华盛顿大学、艾伦人工智能研究所等机构联合创建了CulturalBench。这个数据集包含1,227个由人类编写和验证的问题,覆盖了包括被边缘化地区在内的45个全球区域。CulturalBench的推出&…

python登录功能实现

一.用python实现基本的登录功能 #-----------------1.基本登录功能------------------- nameinput("qq账号:") if name"jc":passwdinput("密码:")if passwd"123456":print("登录成功")else:print(&q…

如何使用Python管理环境变量

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 环境变量 📒📝 环境变量简介📝 Python 中的环境变量操作📝 获取环境变量📝 设置环境变量🔖 临时设置🔖 永久设置📝 删除环境变量📝 临时删除📝 永久删除📝 小结⚓️ 相关链接 ⚓️📖 介绍 📖 环境变量…

设置允许多用户远程登录 Windows 云服务器

操作场景 本文档以 Windows Server 2016 操作系统云服务器为例,指导您配置多用户远程登录 Windows 云服务器。 注意: 微软提供的多用户远程登录功能试用期为120天,若未购买多用户登录授权(RDS CALs),则试…

喜报!景联文科技成功通过DCMM数据管理能力成熟度二级认证

10月30日,中国电子信息行业联合会公示了新一批DCMM贯标企业,景联文科技成功通过DCMM数据管理能力成熟度二级认证(乙方认证)。 DCMM是《数据管理能力成熟度评估模型》的简称,是我国在数据管理领域首个正式发布的国家标准…

Android setContentView执行流程(1)-生成DecorView

setContentView的流程主要就是讲在Activity的onCreate方法中调用setContentView方法之后,我们自定义的xml文件加载的过程,学习它可以让我们对整个View树的理解更加透彻,并且通过源码的学习,我们可以从根本上理解一些问题&#xff…

《操作系统 - 清华大学》2 -1:操作系统的启动

文章目录 0. 内容摘要1. 计算机体系机构概述2.启动2.1 启动时计算机内存和磁盘布局2.2. 内存映射 3. 系统调用、异常、中断3.1 定义3.2 背景3.3 中断、异常和系统调用的不同点3.3.1 源头3.3.2 处理时间3.3.3 响应 0. 内容摘要 两部分的内容 第一部分是启动。知道操作系统怎么是…

在服务器里安装2个conda

1、安装新的conda 下载地址:Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 本文选择:Anaconda3-2023.03-1-Linux-x86_64.sh 安装:Ubuntu安装Anaconda详细步骤(Ubuntu22.04.1&#xff…

【系统集成项目管理工程师】知识点汇总

十五矩阵图 ITTO(Input - Tools & Techniques - Output)一览图 整合管理、范围管理 进度管理、成本管理 成本管理(续)、质量管理、资源管理 沟通管理、风险管理 风险管理(续)、采购管理、干系人管理

Java | Leetcode Java题解之第552题学生出勤记录II

题目: 题解: class Solution {static final int MOD 1000000007;public int checkRecord(int n) {long[][] mat {{1, 1, 0, 1, 0, 0},{1, 0, 1, 1, 0, 0},{1, 0, 0, 1, 0, 0},{0, 0, 0, 1, 1, 0},{0, 0, 0, 1, 0, 1},{0, 0, 0, 1, 0, 0}};long[][] re…

极品模板内容付费管理系统(PHP内容知识付费系统)

极品模板内容付费管理系统是一款基于PHP和MySQL技术开发的源码产品,旨在为用户提供一个功能全面、易于管理和扩展的内容付费平台。该系统支持多种付费模式,具备强大的内容管理功能,适合各类内容创作者和企业家构建知识付费、会员服务、在线教…

设计者模式之策略模式

前言 在软件构建过程中,某些对象使用的算法可能多种多样,经常改变,如果将这些算法都写在对象中,将会使对象变得异常复杂;而且有时候支持不频繁使用的算法也是一个性能负担。 如何在运行时根据需要透明地更改对象的算…

【AIGC】如何通过ChatGPT轻松制作个性化GPTs应用

创建个性化的GPTs应用是一个涉及技术、设计和用户体验的过程。以下是详细步骤: ###1.确定应用目标和用户群体 在开始之前,你需要明确你的应用的目标和目标用户。这将帮助你在设计、开发和个性化方面做出相应的决策。例如,如果你的应用是为了…

LeetCode 热题 100之 堆

1.数组中第k个最大元素 和Acwing 786 第k个数一模一样 排序 思路分析1:此题要求时间复杂度未为O(n)。虽然库函数sort和快速排序都能过,但是时间复杂度不满足条件。下面优化快速排序,写一个快速选择算法。我们可以引入随机化来加速这个过程&…

redis笔记-数据结构

zset zset一方面它是一个 set,保证了内部value 的唯一性,另一方面它可以给每个 value 赋予一个 score,代表这个 value 的排序权重。 zset的底层是由字典和跳表实现。 字典主要用来存储value和score的对应关系。跳表这个数据结构主要用来提…

day20-21之间的项目实战:若依ruoyi开发(可以跳过)

一,项目概述 官网文档地址:http://doc.ruoyi.vip/ rouyi是一个后台管理系统,基于经典技术组合(spring boot,apache shiro,mybatis,thymeleaf)主要是让开发者注重专注业务&#xff0…

【Android】名不符实的Window类

1.“名不符实”的Window类 Window 是一个窗口的概念,是所有视图的载体,不管是 Activity,Dialog,还是 Toast,他们的视图都是附加在 Window 上面的。例如在桌面显示一个悬浮窗,就需要用到 Window 来实现。Wi…

SDL事件相关

文章目录 事件相关的函数和数据结构用户自定义事件代码相关: 事件相关的函数和数据结构 SDL_WaitEvent :等待一个事件SDL_PushEvent 发送一个事件SDL_PumpEvents(): 将硬件设备产生的时间放入事件队列 ,用于读取事件,在调用该函数之前&#…

机器人课程——使用TIA Portal V15博图软件进行西门子组态——带显示屏

一.打开TIA Portal V15博图软件创建项目 1.选择创建新项目 创建完成后选择PLC 二.创建完成后选择设备PLC (此处以S7-1200 1214FC DC/DC/DC 为例) 三.添加扩展板(如有——这里以223-1BL32-0XB0为例) 四.更改扩展版地址 五.添加触摸屏(这里以…