实验一创建数据库及关系表数据完整性约束精编版
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验一创建数据库及关系表数据完整性约束精
编版
MQS system office room 【MQS16H-TTMS2A-MQSS8Q8-MQSH16898】
实验一创建数据库及关系表、数据完整性约束
网工1203熊健羲
一、实验目的
1.???掌握SQLServer数据库管理系统的使用,能够在该环境中进行日常数据库操作;
2.???掌握在SQLServer中使用图形化工具创建数据库的方法;
3.掌握建立关系表的语句,掌握定义主码约束及外码约束的语句;
4.掌握修改表结构的语句。
5.掌握数据完整性约束的功能。
二、实验内容和步骤
1.创建符合如下条件的数据库:
数据库的名字为:Students
数据文件的逻辑文件名为:Students_dat,存放在用户盘某目录下;
文件的初始大小为:5MB;增长方式为自动增长,每次增加1MB。
实验结果:
2.在已建立的Students数据库中,确定出各表中的数据类型,写出创建满足下述条件的四张表的SQL语句,并查看执行结果。
实验结果:
3.写出实现如下操作的SQL语句,并查看执行结果:
(1)在选课表中添加一个新的修课类别列:列名为:选课类别,类型为char(4)。
(2)将课程表中的学分列的类型改为:tinyint(微整型,取值范围在0~255)。
(3)删除学生表的专业列。
(4)为教师表添加主码约束,其主码列为:教师号。
实验结果:
4.在Students数据库中,编写建立满足完整性要求的定义表的SQL语句,执行并观察执行结果。
(1)图书表,结构如下:
书号:统一字符编码定长类型,长度为6,主码,
书名:统一字符编码可变长类型,长度为30,非空,
第一作者:普通编码定长字符类型,长度为10,非空,
出版日期:小日期时间型,小于等于当前系统日期,(用getdate()实现)
印刷数量:小整型,取值范围:1000~5000,默认为4000,
价格:定点小数,小数部分一位,整数部分3位。
实验结果:
(2)书店表,结构如下:
书店编号:统一字符编码定长类型,长度为6,主码,
店名:统一字符编码可变长类型,长度为30,非空,
电话:普通编码定长字符类型,12位长,取值形式:010-8位数字
地址:普通编码可变长字符类型,40位长。前两个字符必须是:北京。
实验结果:
(3)图书销售表,结构如下:
书号:统一字符编码定长类型,长度为6,非空,
书店编号:统一字符编码定长类型,长度为6,非空,
销售日期:小日期时间型,非空,默认值为系统当前日期,
销售数量:微整型,取值大于0,主码(书号,书店编号,销售日期);
书号为引用“图书表”的外码;书店编号为引用“书店表”的外码。
实验结果:
5.执行下列两条数据插入语句,是否都能执行成功?为什么?
INSERTINTO Book
VALUES('T0001','数据库系统基础','张三','2010-2-1',3000,
实验结果:能执行
INSERTINTO Book
VALUES('T0002','计算机网络','张三','2010-1-1',500,
实验结果:不能执行,原因:印刷数量小于1000
6.执行下列数据插入语句,是否执行成功?为什么?
INSERTINTO Store VALUES('S001','新华书店',,'北京市海淀区')
实验结果:不能执行,原因:电话号码不符合标准
7.执行一条数据插入语句,是否执行成功?为什么?
INSERTINTO Sale(书号,书店编号,销售数量)VALUES('T0001','S001',20)
实验结果:不能执行,原因:store是sale外键,其中store并没有添加进数据。
三、实验源码
CREATEtable Student(
学号CHAR(7)primarykey,
姓名NCHAR(5)notnull,
性别NCHAR(1),
年龄TINYINT,
所在系NVARCHAR(20),
专业NVARCHAR(20)
)
CREATEtable Course(
课程号CHAR(6)primarykey,
课程名NVARCHAR(20)NOTNULL,
学时数TINYINT,
学分TINYINT
)
CREATETABLE SC(
学号CHAR(7)NOTNULL,
课程号CHAR(6)NOTNULL,
成绩TINYINT,
PRIMARYKEY(学号,课程号),
FOREIGNKEY(学号)REFERENCES Student(学号),
FOREIGNKEY(课程号)REFERENCES Course(课程号)
)
CREATEtable Teather(
教师号CHAR(7)notnull,
教师名NCHAR(5)notnull,
所在部门NVARCHAR(20),
工资Smallmoney,
出生日期Smalldatetime
)
select*from Student
select*from Course
select*from SC
select*from Teather
ALTERTABLE SC
ADD选课类别char(4)
ALTERTABLE Course
ALTERCOLUMN学分tinyint
ALTERTABLE Student
DROPCOLUMN专业
ALTERTABLE Teather
ADDconstraint ys primarykey(教师号)
CREATEtable Book(
书号NCHAR(6)primarykey,
书名Nvarchar(30)notnull,
第一作者CHAR(10)notnull,
出版日期smalldatetimecheck(出版日期 印刷数量Smallintcheck(印刷数量<5000and印刷数量>1000)default(4000), 价格decimal(3,1) ) CREATEtable Store( 书店编号NCHAR(6)primarykey, 店名NVARCHAR(30)NOTNULL, 电话Char(12)check(电话like'010-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'),地址Varchar(40)check(地址like'北京%') ) Createtable Sale (