第五章王珊,萨师煊版《数据库系统概论》讲义与课后习题答案课件.ppt
文本预览下载声明
;;数据库完整性;数据的完整性和安全性是两个不同概念
数据的完整性
防止数据库中存在不符合语义的数据,也就是防止数据库中存在不正确的数据
防范对象:不合语义的、不正确的数据
数据的安全性
保护数据库防止恶意的破坏和非法的存取
防范对象:非法用户和非法操作
;数据库完整性(续);完整性约束条件;完整性约束条件;完整性约束条件分类;完整性约束条件(续);完整性约束条件(续);完整性约束条件(续);完整性约束条件(续);完整性约束条件(续);完整性约束条件(续);函数依赖约束;统计约束;完整性约束条件(续);完整性约束条件(续);完整性约束条件(续);完整性约束条件(续);完整性约束条件小结;5.2 完整性控制;一、DBMS的完整性控制机制;DBMS的完整性控制机制(续);DBMS的完整性控制机制(续);DBMS的完整性控制机制(续);DBMS的完整性控制机制(续);DBMS的完整性控制机制(续);DBMS的完整性控制机制(续);二、关系系统三类完整性的实现;三、参照完整性的实现; 1. 外码是否可以接受空值的问题;1. 外码是否可以接受空值的问题;1. 外码是否可以接受空值的问题;2.在被参照关系中删除元组时的问题;2.在被参照关系中删除元组时的问题;2.在被参照关系中删除元组时的问题;2.在被参照关系中删除元组时的问题;2.在被参照关系中删除元组时的问题;2.在被参照关系中删除元组时的问题;3.在参照关系中插入元组时的问题;3.在参照关系中插入元组时的问题;3.在参照关系中插入元组时的问题;4. 修改被参照关系中主码的问题;允许修改主码策略;允许修改主码策略;允许修改主码策略;允许修改主码策略;允许修改主码策略;允许修改主码策略;参照完整性的实现;5.3 MySQL的完整性;一、MySQL中的实体完整性;MySQL中的实体完整性(续);MySQL中的实体完整性(续);MySQL中的实体完整性(续);二、MySQL中的参照完整性;MySQL中的参照完整性(续);MySQL中的参照完整性(续);MySQL中的参照完整性(续);MySQL中的参照完整性(续);三、MySQL中用户定义的完整性;MySQL中用户定义的完整性(续);MySQL中用户定义的完整性(续);MySQL中用户定义的完整性(续);MySQL中用户定义的完整性(续);MySQL中用户定义的完整性(续);触发器是数据库模式的一个元素,它有下面的结构:
ON事件IF前提条件THEN行为
其中,事件是对执行某个数据库操作的请求(例如,向学生表中插入一行),前提条件是一个表达式,它的值为true或false(例如,),而行为是一个语句,它指出当触发器被触发时(也即当事件发生且前提条件为真时)应该完成什么(例如,从数据库中删除某些东西)。; 下面的触发器,它的目的是确保注册的学生不超过课程班的容量:
ON 在课程注册表中插入一行
IF 超过课程班容量
THEN 取消注册事务;CREATE TRIGGER语法格式
CREATE TRIGGER 触发器名
{BEFORE | AFTER} 触发事件 ON 表名
FOR EACH {ROW | STATEMENT}
[WHEN 触发条件]
触发动作体
;定义触发器(续);定义触发器(续);定义触发器(续);定义触发器(续);定义触发器(续);定义触发器(续);定义触发器(续);MySQL中用户定义的完整性(续);MySQL中用户定义的完整性(续);MySQL完整性小结;小结
显示全部