- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第五章数据库完整性.
第五章 数据库完整性
5.1实体完整性 1
5.1.1 实体完整性定义 1
5.1.2 实体完整性检查和违约处理 2
5.2 参照完整性 3
5.2.1 参照完整性定义 3
5.2.2参照完整性检查和违约处理 4
5.3用户定义的完整性 6
5.3.1 属性上的约束条件的定义 6
5.3.2 属性上的约束条件检查和违约处理 8
5.3.3元组上的约束条件的定义 8
5.3.3元组上的约束条件检查和违约处理 8
5.4完整性约束命名子句 9
*5.5域中的完整性限制 10
5.6 触发器 11
5.6.1 定义触发器 11
5.6.2激活触发器 13
5.6.3删除触发器 14
数据库的完整性是指数据的正确性和兼容性。
数据的完整性是为了防止数据库中存在不符合语义的数据,也就是防止数据库中存在不正确的数据。数据的安全性是保护数据库防止恶意的破坏和非法的存取。
为维护数据库的完整性,DBMS必须能够;
提供定义完整性约束条件的机制
提供完整性检查的方法
违约处理
我们在第2章2.3已经讲解了关系数据库三类完整性约束约束的基本概念,下面讲解SQL语言中实现这些完整性控制功能的方法。
5.1实体完整性
5.1.1 实体完整性定义
1. 将STUDENT表中的SNO属性定义为码。
CREATE TABLE Student
(Sno CHAR(9)PRIMARY KEY,/*在列级定义主码*/
Sname CHAR(20) NOT NULL,
Ssex CHAR(2),
Sage SMALLINT,
Sdept CHAR(20)
);
或者
CREATE TABLE Student
(Sno CHAR(9),
Sname CHAR(20)NOT NULL,
Ssex CHAR(20),
Sage SMALLINT,
Sdept CHAR(20),
PRIMARY KEY (Sno) /*在表级定义主码*/
);
2. 将SC表中的Sno,Cno属性组定义为码
CREATE TABLE SC
(Sno CHAR(9) NOT NULL,
Cno CHAR(4) NOT NULL,
Grade SMALLINT,
PRIMARY KEY(Sno,Cno) /*只能在表级定义主码*/
);
5.1.2 实体完整性检查和违约处理
包括:
检查主码值是否唯一,如果不唯一则拒绝插入或修改。
检查主码的各个属性是否为空,只要有一个为空就拒绝插入或修改。从而保证了实体完整性。
全表扫描是十分耗时的。为了避免对基本表进行全表扫描,RDBMS核心一般都在主码上自动建立一个索引,如图5.2的B+树索引。通过索引查找基本表中是否已经存在新的主码值,将大大提高效率。
图5.2 使用索引检查主码唯一性
5.2 参照完整性
5.2.1 参照完整性定义
例如,关系SC中一个元组表示一个学生选修的某门课程的成绩,(Sno,Cno)是主码。Sno,Cno分别参照引用Student表的主码和Course表的主码。
3.定义SC中的参照完整性
CREATE TABLE SC
(Sno CHAR(9) NOT NULL,
Cno CHAR(4) NOT NULL,
Grade SMALLINT,
PRIMARY KEY(Sno,Cno), /*在表级定义实体完整性*/
FOREIGN KEY(Sno)REFERENCES Student(Sno),
/*在表级定义参照完整性*/
FOREIGN KEY(Cno)REFERENCES Course(Cno)
/*在表级定义参照完整性*/
);
5.2.2参照完整性检查和违约处理
一个参照完整性将两个表中的相应元组联系起来了。因此,对被参照表和参照表进行增删操作时有可能破坏参照完整性,必须进行检查。
例如,对表SC和Student有四种可能破坏参照完整性的情况,如表5.1所示。
SC表中增加一个元组,该元组的Sno属性的值在表Student中找不到一个元组,其Sno属性的值与之相等。
修改SC表中的一个元组,修改后该元组的Sno属性的值在表Student中找不到一
您可能关注的文档
最近下载
- 并网光伏电站项目工程现场电气二次施工方案.doc
- 英语新课标背景下:非纸笔测试在小学英语期末评价中的实践研究.pdf VIP
- 液体伤口敷料产品技术要求标准2023版.docx VIP
- 股市实战绝技汇总篇(精华).doc VIP
- 历年行情的十大牛股.doc VIP
- 安徽省六校联考暨安徽六校教育研究会2026届高三入学素质检测-物理试卷答案.docx VIP
- 基于Ansys CFX的风扇叶片双向流固耦合分析.docx VIP
- (高清版)DB1307∕T 334-2020 蛋鸡无抗养殖技术规范.pdf VIP
- 中小学教育班班通系统校级解决方案.doc VIP
- 涉税检举奖励制度的运行问题...于68份裁判文书的考察分析_金超.pdf VIP
文档评论(0)