SQL实验六数据完整性.docx
《SQL实验六数据完整性.docx》由会员分享,可在线阅读,更多相关《SQL实验六数据完整性.docx(11页珍藏版)》请在冰豆网上搜索。
SQL实验六数据完整性
实验6数据完整性
一、实验目的
1.掌握Transact-SQL语句(CREATERULE、DROPRULE)创建和删除规则的方法。
2.掌握系统存储过程sp_bindrule、sp_unbindrule绑定和解除绑定规则的操作方法,以及sp_help、sp_helptext查询规则信息、sp_rename更名规则的方法。
3.掌握Transact-SQL语句(CREATEDEFAULT、DROPDEFAULT)创建和删除默认对象的方法。
4.掌握系统存储过程sp_bindefault、sp_unbindefault绑定和解除绑定默认对象的操作方法,以及sp_helptext查询规则信息。
5.掌握SQLServer管理平台和Transact-SQL语句(CREATETABLE、ALTERTABLE)定义和删除约束的方法,并了解约束的类型。
二、实验内容和步骤
1.为studentsdb数据库创建一个规则,限制所输入的数据为7位0~9的数字。
(1)复制学生表命名为stu_phone,在stu_phone表中插入一列,列名为“电话号码”。
完成以下代码实现该操作。
SELECT*INTOstu_phoneFROM学生表
ALTERTABLEstu_phoneADDCHAR(7)NULL
stu_phone表结构如图1-10所示。
图1-10stu_phone表结构
(2)创建一个规则phone_rule,限制所输入的数据为7位0~9的数字。
(3)使用系统存储过程sp_hndrule将phone_rule规则绑定到stu_phone表的“电话号码”列上。
(4)插入操作输入以下数据:
学号姓名电话号码
0009王国强1234yyy
是否可以成果插入?
不可以
如果出现错误,请列出错误信息,为什么会产生该出错信息?
消息213,级别16,状态1,第1行
插入错误:
列名或所提供值的数目与表定义不匹配。
如果要实现插入操作,应修改INSERTINTO语句中的哪个值?
phone_rule规则能否对其他操作(如DELETE)进行规则检查?
2.创建一个规则stusex_rule,将其绑定到stu_phone表的“性别”列上,保证输入的性别值只能是“男”或“女”。
3.使用系统存储过程sp_help查询stusex_rule规则列表,使用sp_helptext查询stusex_rule规则的文本,使用sp_rename将stusex_rule规则更名为stu_s_rule。
4.删除stu_s_rule规则。
注意:
stu_s_rule为stusex_rule更名后规则名,是否仍然绑定在stu_phone表的“性别”列上,应如何操作才能删除它。
5.在studentdb数据库中,建立日期、货币和字符等数据类型的默认对象。
(1)创建默认对象df_date、df_char、df_money。
●创建日期型默认对象df_date,默认日期为2006-4-12。
●创建字符型默认对象df_char,默认字符为“unknown”
●创建货币型默认对象df_money,默认为100元
(2)在studentsdb数据库中创建stu_fee数据表。
学号char(10)NOTNULL
姓名char(8)NOTNULL,
学费money
交费日期datetime
电话号码char(7)
表stu_fee的数据结构如图1-11所示。
学号
姓名
性别
交费日期
电话号码
图l-11stu_fee的数据结构
(3)使用系统存储过程sp_bindehult将默认对象df_date、df_char、df_money分别绑定在stu_fee表的“学费”、“交费日期”、“电话号码”列上。
(4)输入命令,在stu_fee表进行插入操作:
(学号,姓名)values('0001',’刘卫平’)
(学号,姓名,学费)values('0001',’张卫民’,$120)
(学号,姓名,学费,交费日期)values('0001',‘马东‘,$110,’2006-5-12‘)
分析stu_fee表中插入记录的各列的值是什么?
(5)完成以下代码解除默认对象df_char、df_date、df_money的绑定,并删除之。
6.为学生表添加一列,命名为“院系”,创建一个默认对象stu_d_df,将其绑定到学生表的“院系”列上,使其默认值为“信息院”,对学生表进行插入操作,操作完成后,删除该默认对象。
7.在studentsdb数据库中用CREATETABLE语句创建表stu_con,并同时创建约束。
(1)创建表的同时创建约束。
表结构如图1-12所示。
图1-12要创建的表的结构
约束要求如下:
①将学号设置为主键(PRIMARYKEY),主键名为pk_sid。
②为姓名添加唯一约束(UNIQUE),约束名为uk_name。
③为性别添加默认约束(DEFAULT),默认名称为df_sex,其值为“男”
④为出生日期添加属性值约束(CHECK),约束名为ck_bday,其检查条件为:
出生日期>'1988-1-1’。
(2)在stu_con表中插入如表1-1所示的数据记录。
表1-1在stu_con表中插入的数据
学号
姓名
性别
出生日期
家庭住址
0009
张小东
1989-4-6
0010
李梅
男
1983-8-5
0011
王强
1988-9-10
0012
王强
1989-6-3
分析各约束在插入记录时所起的作用,查看插入记录后表中数据与所插入的数据是否一致?
(3)使用ALTERTABLE语句的DROPCONSTRAINT参数项在查询分析器中删除为stu_con表所建的约束。
8.用对象资源管理器中数据库关系图为studentsdb数据库的成绩表添加外键约束(FOREIGNKEY),要求将“学号”设置为外键,参照表为学生表,外键名称为fk_sid。
⑴使用系统存储过程sp_help查看成绩表的外键信息。
⑵在成绩表中插入表1-2所示记录,观察SQLServer会做何处理,为什么?
如何解决所产生的问题?
表1-2
学号
课程编号
分数
0100
0001
78
四、实验思考
1.在SQLServer2005中,可采用哪些方法实现数据完整性?
2,比较默认对象和默认约束的异同。
3.在数据库中建立的规则不绑定到到数据表的字段上会起作用吗?
为什么?