第5章 数据库完整性.ppt_第1页
第5章 数据库完整性.ppt_第2页
第5章 数据库完整性.ppt_第3页
第5章 数据库完整性.ppt_第4页
第5章 数据库完整性.ppt_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论