- 1、本文档共2页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库第10章数据库完整性
第十章 数据库完整性
习题
1.什么是数据库的完整性?
2.数据库的完整性概念与数据库的安全性概念有什么区别与联系?
3.什么是数据库的完整性约束条件?可分为哪几类?
4.DBMS的完整性机制应具有哪些功能?
5.RDBMS在实现参照完整性时需要考虑哪些方面?
6.假设有两个关系模式:
职工(职工号,姓名,年龄,职务,工资,部门号),其中职工号为主码;
部门(部门号,名称,经理名,地址,电话号),其中部门号为主码。
用SQL语言定义这两个关系模式,要求在模式中完成一下完整性约束条件的定义:
定义每个模式的主码;定义参照完整性;定义职工年龄不得超过60岁。
7.关系系统中,当操作违反实体完整性、参照完整性和用户定义的完整性约束条件时,一般是如何分别进行处理的?
8.试述你了解的某一个实际的DBMS产品的完整性控制策略。
参考答案
1.答:数据库的完整性是指数据库的正确性和兼容性。
2.答:数据的完整性和安全性是两个不同的概念,但是有一定的联系。
前者是为了防止数据库中存在不符合语义的数据,防止错误信息的输入和输出,即所谓垃圾进垃圾出所造成的无效操作和错误结果。
后者是保护数据库防止恶意的破坏和非法的存取。
也就是说,安全性措施的防范对象是非法用户和非法操作,完整性措施的防范对象是不合语义的数据。
3.答:完整性约束条件是指数据库中的数据应该满足的语义约束条件。一般可以分为六类:静态列级约束,静态元组约束,静态关系约束,动态列级约束,动态元组约束,动态关系约束。
静态列级约束是对一个列的取值域的说明,包括以下几个方面:
对数据类型的约束,包括数据的类型,长度,单位,精度等;
对数据格式的约束;
对取值范围或取值集合的约束;
对空值的约束;
其他约束
静态元组约束就是规定组成一个元组的各个列之间的约束关系,静态元组约束只局限在单个元组上。
静态关系约束是在一个关系的各个元组之间或者若干关系之间常常存在各种联系或约束。常见的静态关系约束有:
实体完整性约束;
参照完整性约束;
函数依赖约束;
动态列级约束是修改列定义或列值时应满足的约束条件,包括下面两个方面:
修改列定义时约束;
修改列值时的约束。
动态元组约束是指修改某个元组的值时需要参照其旧值,并且新旧值之间需要满足某种约束条件。
动态关系约束是加在关系变化前后状态上的限制条件,例如事务一致性,原子性等约束条件。
详细内容可以参见概论10.1中的介绍。
4.答:DBMS的完整性控制机制应具有三个方面的功能:
(1)定义功能,即提供定义完整性约束条件的机制;
(2)检查功能,即检查用户发出的操作请求是否违背了完整性约束条件;
违约反应:如果发现用户的操作请求使数据违背了完整性约束条件,则采取一定的动作来保证数据的完整性。
5.答:RDBMS在实现参照完整性时需要考虑以下几个方面:
(1)外码是否可以接受空值。
(2)删除被参照关系的元组时的考虑,这时考虑可能采取的作法有三种:
级联删除(CASCADES)
受限删除(RESTRICTED)
置空值删除(NULLIFIES)
(3)参照关系中插入元组时的问题,这时系统可能采取的作法有:
受限插入
递归插入
(4)修改关系中主码的问题。一般是不能用UPDATE语句修改关系主码的。如果需要修改主码值,只能先删除该元组,然后再把具有新主码值的元组插入到关系中。如果允许修改主码,首先要保证主码的唯一性和非空,否则拒绝修改。然后要区分是参照关系还是被参照关系。
详细讨论可以参见《概论》10.2
6.答:
CREATE TABLE DEPT
( Deptno NUMBER(10),
Deptname VARCHAR(10),
Manager VARCHAR(10),
PhoneNumber CHAR(12)
CONSTRAINT PK_SC PRIMARY KEY (Deptno));
CREATE TABLE EMP
( Empno NUMBER(4)
Ename VARCHAR(10)
Age NUMBER(2)
CONSTRAINT C1 CHECK (Age=60),
Job VARCHAR(9),
Sal NUMBER(7,2)
Deptno NUMBER(2)
CONSTRAINT FK_DEPTNO
FOREIGN KEY(Deptno)
REFERENCES DEPT(Deptno));
7.答:对于违反实体完整性和用户定义的完整性的操作一般都采用拒绝的方法进行处理。而对于违反参照完整性的操作,并不都是简单地拒绝执行,有时要根据应用语义执行一些附加的操作,以保证数据库的正确性。具体的处理可以见上面第5题或概论
文档评论(0)