1、数据库系统原理,计算机实验教学中心,实验六 数据完整性,实验目的 实验环境实验内容 实验步骤,实验目的,熟练掌握在SQL Server2000中用T-SQL语句定义数据完整性,加深对数据完整性的理解。,实验环境,微型计算机一台 。WINDOWS操作系统、 SQL Server2000。,实验内容,数据库的完整性设置实体完整性域完整性参照完整性,实验步骤:,实体完整性将“student”表的“sno”字段设为主键:当“student”表已存在则执行:alter table student add constraint pk_sno primary key (sno)当“student”表不存在则
2、执行: Create table student(sno CHAR(5) primary key , sname CHAR(10),ssex CHAR(2),sage int,sdept CHAR(4),添加一身份证号字段,设置其惟一性.(注: 操作前应删除表中的所有记录)Alter table student add id char(18) unique (id),3. 将“sc”表的“sno”和“cno”设置为主键:当“sc”表已存在则执行alter table sc add constraint PK_SnoCno primary key (sno,cno)当“sc”表不存在则执行:Cr
3、eate table sc(sno CHAR(5),cno CHAR(2),grade INT NULL,constraint PK_SnoCno primary key (sno,cno),域完整性4. 将“ssex”字段设置为只能取“男”,“女”两值;当“student”表已存在则执行: alter table student add constraint CK_Sex check (ssex in (男 ,女)当“student”表不存在则执行:Create table student(sno CHAR(5) primary key , sname CHAR(10),ssex CHAR(
4、2) check (ssex in (男 ,女) ,sage int, sdept CHAR(4),5. 设置学号字段只能输入数字; alter table student add constraint CK_Sno_Format check (sno like 0-90-90-90-90-9),6. 设置身份证号的输入格式; alter table student add constraint CK_ID_Format check (id like 0-90-90-90-90-90-91-20-90-90-90-10-90-30-90-90-90-9_) OR (id like 0-90-9
5、0-90-90-90-90-90-90-10-90-30-90-90-90-9),7. 设置18位身份证号的第7位到第10位为合法的年份(1900-2050); alter table student add constraint CK_ID_Format2 check ( not len(id)=18 or ( (convert(smallint,substring(id,7,4) )=1900) and(convert(smallint,substring(id,7,4) )=22 or sex=女 and sage=20 ),10. 将“student”表和“sc”表中的“sno”字段设
6、为参照;当“sc”表已存在则执行: alter table sc add constraint FP_sno foreign key (sno) references student(sno )当“sc”表不存在则执行: Create table sc(sno CHAR(5) constraint FP_sno foreign key references student(sno), cno CHAR(2),grade INT NULL, constraint PK_SnoCno primary key (sno,cno) ),验证实体完整性下面的语句用来验证“sc”表中的实体完整性:inse
7、rt into sc values(95002, 10,65)insert into sc values(95002, 10,90),验证域完整性; insert into student values(95009,张匀,大,20,CS),验证参照完整性;使用下面的语句“验证”sc表中的“sno”字段的域完整性(假设student表中没有学号为“95998”的学生记录):insert into sc values(98998, 10,98),思考,建立课程的实体完整性, 和课程号cno的参照完整性;*建立年龄的域完整性, 约束条件为“年龄在15到30岁之间”在学生表中添加“出生日期”和“身份证号”字段,设置一完整性规则,确保身份证号中的关于出生日期的数字与“出生日期”字段的值相匹配。,