- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验九 数据完整性约束实现
姓名: 计算机科学与技术 学号: 专业: 班级: 同组人: 无 实验日期:
【实验目的与要求】
熟练掌握实体完整性的实现。
熟练掌握参照完整性的实现。
熟练掌握域完整性的实现。
【实验内容与步骤】
实验准备:对于CPXS数据库,若在CP表、CPXSB表和XSS表上已有约束,请先删除之。
实体完整性的实现
(1) 对CP表,定义主键约束(用企业管理器实现)。
写出相应过程:
修改cp表,把产品编号设为主键
测试:试着对CP表插入一条与原表中数据行具有相同主键值的数据。
给出测试结果:
(2)对CPXSB表、XSS表,定义主键约束(用SQL语句实现,写出相应语句)。
给出相应的SQL语句:
ALTER TABLE CPXSB
ADD CONSTRAINT PK_UNION PRIMARY KEY (产品编号,客户编号,销售日期)
ALTER TABLE XSS
ADD CONSTRAINT PK_CTNUM PRIMARY KEY (客户编号)
给出测试结果:
参照完整性的实现
(1)利用企业管理器建立CP表与CPXSB之间的参照关系,当对主表CP表进行更新和删除操作时,从表CPXSB采用NO ACTION方式,写出其过程。
给出相应的过程:
点击修改cpxsb表,在外键关系中,外键来自cp表中的产品编号,insert和update规范中,更新规则和删除规则均设置为无操作
测试:试着删除主表中与从表有关联的一条记录,而后分别查看主表和从表中数据记录,给出测试结果。
删除cp表中第一条记录,结果如下:
主表和从表的记录不变。
(2)利用SQL语句建立CPXSB与XSS表之间的参照关系,当对主表XSS表进行更新和删除操作时,从表CPXSB采用CASCADE(级联)方式,写出其过程。
给出相应的SQL语句:
ALTER TABLE CPXSB
ADD CONSTRAINT FK_UNION FOREIGN KEY (客户编号)
REFERENCES XSS (客户编号)
ON DELETE CASCADE
ON UPDATE CASCADE
测试:试着删除主表中与从表有关联的一条记录,而后分别查看主表和从表中数据记录,给出测试结果。
删除XSS表中客户编号为7的记录,如图
CPXSB中客户编号为7的记录均被删除,如图:
思考:外键参照关系中CASCADE(级联)和NO ACTION方式的作用各是什么?
CASCADE:对主表删除或修改,从表中关联的记录同样被删除或修改。
NO ACTION:对主表进行删除或修改,若从表中有关联记录,则不允许该操作执行。
域完整性的实现
1.Unique约束
(1)在CP表的“产品名称”列定义一个唯一约束。
给出相应的SQL语句:
ALTER TABLE CP
ADD CONSTRAINT UQ_TYPE UNIQUE(产品名称)
测试:试着在在CP表中插入一条具有与原表中某记录相同“产品名称”值的数据。
给出测试结果:
2.Check约束
(1)在CP表的价格列上定义大于等于0的检查(CHECK)约束。
给出相应的SQL语句:
ALTER TABLE CP
ADD CONSTRAINT CHE_TYPE CHECK(价格=0)
测试:试着在CP表中插入一条记录,其“价格”字段的值小于0(如: -2),给出测试结果:
(2)定义一个大于等于5的规则check_kcl,并将其绑定到CP表的库存量列,
给出相应的SQL语句:
ALTER TABLE CP
ADD CONSTRAINT CHECK_KCL CHECK(库存量=5)
测试:试着在CP表中插入一条记录,其“库存量”字段的值小于5(如:2),给出测试结果:
(3)解除(2)中绑定,删除该规则,请写出相关SQL语句。
给出相应的SQL语句和运行结果截图:
ALTER TABLE CP
DROP CONSTRAINT CHECK_KCL
测试:试着在CP表中插入一条记录,其“库存量”字段的值小于5(如:2),给出测试结果:
思考:比较(2)和(3)的测试结果,理解自定义完整性(约束)的作用?
能够对表中某一属性的值进行限制
完成以下实验练习
(1) 设定XSS表中的地区值只能是“镇江”,“无锡”,“上海”,“南京”,“厦门”中的任意一个,请问如何解决该问题?请写出一种具体的解决方法。
给出相应的SQL语句:
ALTER TABLE XSS
ADD CONSTRAINT CHECK_DQ CHECK(地区 IN (镇江,无锡,上海,南京,厦门))
测试:试着在XXS表中插入一条记录,其“地区”字段的值为福州。
给出测试结果:
(2) 用户要求:在输入XSS表中的数据时,若“地区”列没有提供
原创力文档


文档评论(0)