项目9完整性管理综述.pptx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
项目九 完整性管理 9.2项目目的 深入理解数据库完整性的重要作用; 掌握SQL Server 2005对三种不同的数据库完整性的实现方法。 9.3 项目内容与要求 为数据表book设定主键(ISBN),并尝试部分违背book实体完整性约束要求的元组(如两行具有相同的ISBN的数据、ISBN为空的数据等),注意观察结果; 为数据表item的属性列ISBN建立外键,其参照属性为数据表book的属性列ISBN。将其更新时选项分别依次设置为级联修改等不同选项,然后修改book表中ISBN的属性值,查看表item中相关属性的值的变化情况;将外键参照关系的删除时的选项分别设为级联删除、设为空值等,然后在book表中删除某些元组,查看表item中相关属性的值的变化情况; 使用check方法,为level表中的userLevel属性的取值限制为1-5; 创建一个规则设置价格取值只能大于零,将此规则绑定到数据表book的属性列price上,并尝试输入数据进行测试; 在数据表publisher上建立约束pName_unique,用于限制属性publisherName取值要具有唯一性,并插入数据进行测试; 删除约束pName_unique。 9.4 项目指导 1. 设置主键的方法 2. 建立外键(参照完整性)的方法 3. 使用check方法设置自定义完整性 4. 使用规则保证数据库完整性 5. 使用SQL语句添加、修改约束 1.设置主键的方法 任务1:将数据表book的属性ISBN设置为主键。 在设计数据表或者修改数据表时,将鼠标移动到欲设置为主键的列名上,单击右键,选择“设置主键”,如图9-1所示。另外,还可以在创建数据表或者修改数据表的SQL 语句中使用primary key子句来定义主键。 图9-1 设置数据表的主键 在设置主键后,下列两种情况会导致系统报错,并拒绝插入或者修改数据: (1)当我们试图在数据表中插入主键为null的元组(或者将某个元组的主键取值修改为null), 如图9-2所示; 图9-2 插入主键取值为空的数据 (2)插入两行在主键上取值相同的数据,或者数据修改后出现两行数据的主键取值相同,如图9-3所示。 图9-3 插入两行在主键上取值相同的数据 2. 建立外键(参照完整性)的方法。 任务2:为数据表item的属性列ISBN建立外键,其参照属性为book表的属性ISBN (1)在Microsoft SQL Server Management Studio中,找到数据库bookstore中的item表,右键单击,选择设计。在设计窗口中,单击右键,在菜单中选择“关系(H)…”,如图9-4所示。 图9-4 创建外键关系 (2)在弹出的外键关系窗口中,单击“添加”添加一个关系,并在右边窗口中选中“表和列规范”一栏,单击该栏右边的按钮,如图9-5。 图 9-5 外键关系窗口 (3)在弹出的“表和列”窗口中,选择主键表为book,并选择ISBN列,同时在在外键表item中选择对应的列ISBN,如图9-6所示。 图9-6 指定外键关系的列 (4)在外键关系窗口中,继续设置“INSERT和UPDATE规范”中的“更新规则”和“删除规则”,如图9-7所示。 图9-7 设置更新、删除数据时外键取值的变化规则 (5)在数据表book中修改相应的ISBN的取值、或者删除部分数据后,查看item数据表中的数据变化情况。 3.使用check方法设置自定义完整性 任务3:为level表中的userLevel属性的取值限制为1-5。 (1)在Microsoft SQL Server Management Studio中,找到数据库bookstore中的level表,右键单击,选择设计。在设计窗口中,单击右键,在菜单中选择“CHECK约束(O)…”,如图9-8所示。 图9-8 设置CHECK约束 (2)在弹出的窗口中,单击“添加”,并在右面窗口中,单击“常规—表达式”一栏的右边的按钮,如图9-9所示。 图9-9 添加CHECK约束 (3)在弹出的“CHECK约束表达式”的编辑窗口中,输入如下表达式:(([userLevel])=(5)) and (([userLevel])=(1)),单击确定;并单击“关闭”按钮。 图9-10 设置CHECK约束的表达式 (4)在表level中输入数据,测试约束是否有效。 4. 使用规则保证数据库完整性 任务4:创建一个规则price_rule,设置价格取值不可小于零,并绑定到book表的price 属性进行测试。 (1)在Microsoft SQL Server Management Studio中,新建一个查询,并输入如下代码,并执行: USE bookstore GO CREATE RULE

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档