数据库原理与应用实验09_.docVIP

  • 53
  • 0
  • 约2.38千字
  • 约 8页
  • 2016-06-10 发布于重庆
  • 举报
数据库原理与应用实验09_

实验九 数据完整性约束实现 姓名: 计算机科学与技术 学号: 专业: 班级: 同组人: 无 实验日期: 【实验目的与要求】 熟练掌握实体完整性的实现。 熟练掌握参照完整性的实现。 熟练掌握域完整性的实现。 【实验内容与步骤】 实验准备:对于CPXS数据库,若在CP表、CPXSB表和XSS表上已有约束,请先删除之。 实体完整性的实现 (1) 对CP表,定义主键约束(用企业管理器实现)。 写出相应过程: 修改表--右击---设置主键. 测试:对CP表插入一条与原表中数据行具有相同主键值的数据。 给出测试结果: (2)对CPXSB表、XSS表,定义主键约束(用SQL语句实现)。 给出相应的SQL语句: alter table xss add constraint PK_XSS primary key clustered ( 客户编号)on[primary] alter table cpxsb add constraint PK_CPXSB primary key clustered ( 产品编号, 客户编号)on[primary] 参照完整性的实现 (1)利用企业管理器建立CP表与CPXSB之间的参照关系,当对主表CP表进行更新和删除操作时,从表CPXSB采用NO ACTION方式。 给出相应的过程: 把CP表的产品编号设为主键,把CPXSB的产品编号添加外键,其主键为CP表的产品编号。 测试:试着删除主表中与从表有关联的一条记录,而后分别查看主表和从表中数据记录,给出测试结果。 delete from cp where 产品编号=100001 (2)利用SQL语句建立CPXSB与XSS表之间的参照关系,当对主表XSS表进行更新和删除操作时,从表CPXSB采用CASCADE(级联)方式。 给出相应的SQL语句: alter table cpxsb add constraint PK_CPXSB_11 foreign key ( 客户编号 )references xss ( 客户编号 )on delete cascade on update cascade 测试:试着删除主表中与从表有关联的一条记录,而后分别查看主表和从表中数据记录,给出测试结果。 delete from xss where 客户编号=000004 打开CPXSB表 客户编号为000004的记录被删除 域完整性的实现 1.Unique约束 (1)在CP表的“产品名称”列定义一个唯一约束。 给出相应的SQL语句: alter table cp add unique(产品编号) 测试:试着在在CP表中插入一条具有与原表中某记录相同“产品名称”值的数据。 给出测试结果: insert into cp(产品编号,产品名称,价格,库存量) values(100001,11,100,100) 2.Check约束 (1)在CP表的价格列上定义大于等于0的检查(CHECK)约束。 给出相应的SQL语句: alter table cp add constraint c1 check(价格0) 测试:试着在CP表中插入一条记录,其“价格”字段的值小于0(如: -2),给出测试结果: (2)定义一个大于等于5的规则check_kcl,并将其绑定到CP表的库存量列, 给出相应的SQL语句: alter table cp add constraint kc1 check(库存量=5) 测试:试着在CP表中插入一条记录,其“库存量”字段的值小于5(如:2),给出测试结果: (3)解除(2)中绑定,删除该规则,请写出相关SQL语句。 给出相应的SQL语句和运行结果截图: alter table cp drop constraint kc1 测试:试着在CP表中插入一条记录,其“库存量”字段的值小于5(如:2),给出测试结果: insert into cp(产品编号,产品名称,价格,库存量) values(100001,11,100,2) 完成以下实验练习 (1) 设定XSS表中的地区值只能是“镇江”,“无锡”,“上海”,“南京”,“厦门”. 给出相应的SQL语句: alter table xss add constraint kc1 check(地区=镇江 or 地区=上海or 地区=南京or 地区=厦门) 测试:试着在XXS表中插入一条记录,其“地区”字段的值为福州。 给出测试结果: (2) 用户要求:在输入XSS表中的数据时,若“地区”列没有提供数据,系统应自动取值“厦门”. 给出相应的SQL语句: alter table xss add constraint xss2 default(厦门) for 地区 测试:试着在XX

文档评论(0)

1亿VIP精品文档

相关文档