第5章节数据库完整性.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第5章节数据库完整性

第5章 数据库完整性 5.1 数据库完整性的含义 数据库的完整性是指保护数据库中数据的正确性、有效性和相容性,防止错误的数据进入数据库造成无效操作。 一些完整性约束的例子: 比如年龄属于数值型数据,只能含0,1,…9,不能含字母或特殊符号; 月份只能取1~12之间的正整数; 表示同一事实的两个数据应相同,否则就不相容,如一个人不能有两个学号。 维护数据库的完整性非常重要,数据库中的数据是否具备完整性关系到数据能否真实地反映现实世界。 5.1 数据库完整性的含义(续) 数据库的完整性和安全性是数据库保护的两个不同的方面。 安全性是保护数据库,以防止非法使用所造成数据的泄露、更改或破坏,安全性措施的防范对象是非法用户和非法操作; 完整性是防止合法用户使用数据库时向数据库中加入不符合语义的数据,完整性措施的防范对象是不合语义的数据。 5.2 完整性规则的组成 为了实现完整性控制,数据库管理员应向DBMS提出一组完整性规则,来检查数据库中的数据,看其是否满足语义约束。 这些语义约束构成了数据库的完整性规则,这组规则作为DBMS控制数据完整性的依据。 它定义了何时检查、检查什么、查出错误又怎样处理等事项。 5.2 完整性规则的组成(续) 具体地说,完整性规则主要由以下三部分构成: 1. 触发条件:规定系统什么时候使用规则检查数据; 2. 约束条件:规定系统检查用户发出的操作请求违背了什么样的完整性约束条件; 3. 违约响应:规定系统如果发现用户的操作请求违背了完整性约束条件,应该采取一定的动作来保证数据的完整性,即违约时要做的事情。 5.2 完整性规则的组成(续) 一条完整性规则可以用一个五元组(D,O,A,C,P)来形式化地表示。其中: D(data):代表约束作用的数据对象; O(operation):代表触发完整性检查的数据库操作,即当用户发出什么操作请求时需要检查该完整性规则; A(assertion):代表数据对象必须满足的语义约束,这是规则的主体; C(condition):代表选择A作用的数据对象值的谓词; P(procdure):代表违反完整性规则时触发执行的操作过程。 例如,对于“学号不能为空”的这条完整性约束, D:代表约束作用的数据对象为SNO属性; O(operation):当用户插入或修改数据时需要检查该完整性规则; A(assertion):SNO不能为空; C(condition):A可作用于所有记录的SNO属性; P(procdure):拒绝执行用户请求。 5.4 完整性规则的执行 完整性规则从执行时间上可分为立即执行约束和延迟执行约束 立即执行约束是指在执行用户事务过程中,某一条语句执行完成后,系统立即对此数据进行完整性约束条件检查。 延迟执行约束是指在整个事务执行结束后,再对约束条件进行完整性检查,结果正确后才能提交。 例如,银行数据库中“借贷总金额应平衡”的约束就应该属于延迟执行约束,从账号A转一笔钱到账号B为一个事务,从账号A转出去钱后,账就不平了,必须等转入账号B后,账才能重新平衡,这时才能进行完整性检查。 5.4 完整性规则的执行(续) 如果发现用户操作请求违背了立即执行约束,则可以拒绝该操作,以保护数据的完整性。 如果发现用户操作请求违背了延迟执行约束,而又不知道是哪个事务的操作破坏了完整性,则只能拒绝整个事务,把数据库恢复到该事务执行前的状态。 5.5 关系模型的完整性 关系模型的完整性包括实体完整性,参照完整性和用户定义完整性。 对于违反实体完整性和用户定义完整性规则的操作一般都是采用拒绝执行的方式进行处理。 5.5 关系模型的完整性(续) 对于违反参照完整性的操作,并不都是简单的拒绝执行,一般在接受这个操作的同时,执行一些附加的操作,以保证数据库的状态仍然是正确的。 在被参照关系中删除元组时可有三种不同的策略: 级联删除:将参照关系中所有外码值与被参照关系中要删除元组主码值相同的元组一起删除; 受限删除:仅当参照关系中没有任何元组的外码值与被参照关系中的主码值相同时,系统才执行删除操作,否则拒绝此删除操作; 置空值删除:删除被参照关系的元组,并将参照关系中相应元组的外码值置空值。 5.5 关系模型的完整性(续) 在参照关系中插入元组时的策略 受限插入:仅当被参照关系中存在此相应元组,其主码值与参照关系插入元组的外码值相同时,系统才执行相应操作,否则拒绝此操作。 递归插入:首先向北参照关系插入相应的元组,其主码值等于参照关系插入元组的外码值,然后向参照关系插入元组。 5.5 关系模型的完整性(续) 修改关系中主码的问题: 不允许修改主码 允许修改主码,但必须保证主码的唯一性和非空。当修改的关系是被参照关系时,还必须检查参照关系。有三种策略: 级联修改 受限

文档评论(0)

jdy261842 + 关注
实名认证
文档贡献者

分享好文档!

1亿VIP精品文档

相关文档