- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* 第五章 数据库完整性 数据库的完整性 数据的正确性和相容性:完整性控制是DBMS提供的保证数据库中的数据正确性的机制,目的在于保证合法用户对数据地正确使用,防止不合语义的数据被输入到数据库而造成的数据不一致性。 数据的完整性和安全性是两个不同概念 数据的完整性 防止数据库中存在不符合语义的数据,也就是防止数据库中存在不正确的数据 防范对象:不合语义的、不正确的数据 数据的安全性 保护数据库防止恶意的破坏和非法的存取 防范对象:非法用户和非法操作 * 第五章 数据库完整性 完整性控制机制 完整性约束条件定义机制 完整性约束条件:完整性规则,数据模型的组成部分,约束数据库中数据的语义,数据必须满足此语义约束 DBMS应提供定义数据库完整性约束条件的机制,并把它们作为模式的一部分存入数据库中 完整性检查机制 由DBMS提供,检查用户发出的操作请求是否违背完整性约束条件 违约处理 如果发现用户的操作请求使数据违背了完整性约束条件,则采取一定的动作来保证数据的完整性 关系数据库的三类完整性约束 实体完整性、参照完整性、用户定义的完整性 * 5.1 实体完整性 实体完整性定义 CREATE TABLE中用PRIMARY KEY定义 表级:PRIMARY KEY (主码属性组) 列级:PRIMARY KEY 单属性构成的码:定义为列级或表级约束条件 多属性构成的码:只可定义为表级约束条件 实体完整性检查和违约处理 当插入记录或更新主码列时,DBMS自动进行检查: (1)主码值是否唯一,如果不唯一则拒绝插入或修改 (2)主码的各个属性是否为空,有一个为空就拒绝插入或修改 为了检查记录中主码值是否唯一,一般都在主码上自动建立一个索引,以提高检查效率 * 5.2 参照完整性 参照完整性定义 在CREATE TABLE中定义 FOREIGN KEY 列名 REFERENCES 表名 (列名) [例1] 定义SC中的参照完整性 CREATE TABLE SC ( Sno CHAR(5) REFERENCES S(Sno) , Cno CHAR(3) , Grade int , PRIMARY KEY (Sno, Cno) , FOREIGN KEY (Sno) REFERENCES S(Sno) , FOREIGN KEY (Cno) REFERENCES C(Cno) ) ; * 5.2 参照完整性 参照完整性检查和违约处理 可能破坏参照完整性的情况及违约处理 可能情况 违约处理 在参照表中插入元组 拒绝 在参照表中修改外码值 拒绝 在被参照表中删除元组 拒绝/级联删除/设置为空值 在被参照表中修改主码值 拒绝/级联修改/设置为空值 要设置为空值,外码必须允许空值 默认策略为拒绝执行 * 5.2 参照完整性 [例2] 显式说明参照完整性的违约处理示例 CREATE TABLE SC (Sno CHAR(9) NOT NULL, /*NOT NULL可以省略*/ Cno CHAR(4) NOT NULL, /*NOT NULL可以省略*/ Grade SMALLINT, PRIMARY KEY (Sno, Cno), FOREIGN KEY (Sno) REFERENCES Student(Sno) ON DELETE CASCADE /*级联删除SC表中相应的元组*/ ON UPDATE CASCADE, /*级联更新SC表中相应的元组*/ FOREIGN KEY (Cno) REFERENCES Course(Cno) ON DELETE NO ACTION /*删除course 表中的元组造成与SC表不一致时拒绝删除*/ ON UPDATE CASCADE /*更新course表中的cno时,级联更新SC表中相应的元组*/ ); * 5.3 用户定义的完整性 用户定义的完整性 针对某一具体应用,数据必须满足的语义要求 属性上的约束条件的定义 列值非空(NOT NULL) 列值唯一(UNIQUE) 检查列值是否满足一个布尔表达式(CHECK) [例3] 定义Student表 CREATE TABLE Student (Sno CHAR(9) PRIMARY KEY, Sname CHAR(8) NOT NULL UNIQUE,
您可能关注的文档
最近下载
- 远程医疗下的医学检验技术新模式.docx VIP
- 凯恩帝K1000T-C_V3.1_编程手册_140822.pdf
- 四川大学sci期刊分级方案.pdf VIP
- 研究生学术道德与学术规范-精品课件.ppt VIP
- 绿色黑板风欢迎新同学新生见面会PPT模板.pptx VIP
- T/BGEA001-2019预拌流态固化土填筑工程技术标准 ..pdf VIP
- 四年级上地方课程.doc VIP
- 【素质模型与职业生涯规划】中粮集团培训之“忠良书院”.pdf VIP
- 2025年黑龙江省辅警招聘考试试题带解析附答案(考试直接用).docx VIP
- 《消费者心理与行为分析》第五版 课件 肖涧松 单元1、2 消费者心理与行为概述; 消费者资源、需要和动机.pptx
文档评论(0)