数据库系统概论CH5(部分)习题解答
更新时间:2023-10-18 12:10:01 阅读量: 综合文库 文档下载
- 数据库系统概论除运算推荐度:
- 相关推荐
第五章 数据库完整性
《概论》第五章详细介绍数据库的完整性。数据库的完整性是指数据库中数据的正确性。由于数据库中的数据之间是相互联系的,因此数据库的完整性还包含数据的相容性。
数据库的完整性包括三个方面:完整性约束定义机制、完整性检查机制和违背完整性约束条件时应采取的预防措施。
一、基本知识点
① 需要了解的:什么是数据库的完整性约束条件;完整性约束条件的分类;数据库的完整性概念与数据库的安全性概念的区别和联系。
② 需要牢固掌握的:DBMS完整性控制机制的三个方面,即完整性约束条件的定义、完整性约束条件的检查和违约反应。
③ 需要举一反三的:用SQL语言定义关系模式的完整性约束条件。包括定义每个模式的主码;定义参照完整性;定义与应用有关的完整性。
④ 难点:RDBMS如何实现参照完整性的策略,即当操作违反实体完整性、参照完整性和用户定义的完整性约束条件时,RDBMS应该如何进行处理,以确保数据的正确与有效。其中比较复杂的是参照完整性的实现机制。
二、习题解答和解析
1、 什么是数据库的完整性? 答
数据库的完整性是指数据的正确性和相容性。
2、 数据库的完整性概念与数据库的安全性概念有什么区别和联系? 答
数据的完整性和安全性是两个不同的概念,但是有一定的联系。
前者是为了防止数据库中存在不符合语义的数据,防止错误信息的输入和输出,即所谓垃圾进垃圾出(Garbage In Garbage Out)所造成的无效操作和错误结果。
后者是保护数据库防止恶意的破坏和非法的存取。
也就是说,安全性措施的防范对象是非法用户和非法操作,完整性措施的防范对象是不合语义的数据。
3、 什么是数据库的完整性约束条件?可分为哪几类? 答
完整性约束条件是指数据库中的数据应该满足的语义约束条件。一般可以分为六类:静态列级约束、静态元组约束、静态关系约束、动态列级约束、动态元组约束、动态关系约束。
1
静态列级约束是对一个列的取值域的说明,包括以下几个方面: (1) 对数据类型的约束,包括数据的类型、长度、单位、精度等; (2) 对数据格式的约束;
(3) 对取值范围或取值集合的约束; (4) 对空值的约束; (5) 其他约束。
静态元组约束就是规定组成一个元组的各个列之间的约束关系,静态元组约束只局限在单个元组上。
静态关系约束是在一个关系的各个元组之间或者若干关系之间常常存在各种联系或约束。常见的静态关系约束有: (1) 实体完整性约束; (2) 参照完整性约束; (3) 函数依赖约束。
动态列级约束是修改列定义或列值时应满足的约束条件,包括下面两方面: (1) 修改列定义时的约束; (2) 修改列值时的约束。
动态元组约束是指修改某个元组的值时需要参照其旧值,并且新旧值之间需要满足某种约束条件。
动态关系约束是加在关系变化前后状态上的限制条件,例如事务一致性、原子性等约束条件。
4*、 DBMS的完整性控制机制应具有哪些功能? 答
DBMS的完整性控制机制应具有三个方面的功能:
(1) 定义功能,即提供定义完整性约束条件的机制;
(2) 检查功能,即检查用户发出的操作请求是否违背了完整性约束条件;
(3) 违约反应:如果发现用户的操作请求使数据违背了完整性约束条件,则采取一定的动作来保证数据的完整性。
5*、 RDBMS在实现参照完整性时需要考虑哪些方面? 答
RDBMS在实现参照完整性时需要考虑以下几个方面: (1) 外码是否可以接受空值。
(2) 删除被参照关系的元组时的考虑,这时系统可能采取的作法有三种: 1) 级联删除(CASCADES); 2) 受限删除(RESTRICTED); 3) 置空值删除(NULLIFIES)。
(3) 在参照关系中插入元组时的问题,这时系统可能采取的作法有: 1) 受限插入; 2) 递归插入。
(4) 修改关系中主码的问题。一般是不能用UPDATE语句修改关系主码的。如果需要修改主码值,只能先删除该元组,然后再把具有新主码值的元组插入到关系中。如果允许修改主码,首先要保证主码的惟一性和非空,否则拒绝修改。然后要区分是参照关系还是被参照关系。
2
6、 假设有下面两个关系模式:
部门(部门号,名称,经理名,电话),其中部门号为主码;
职工(职工号,姓名,年龄,职务,工资,部门号),其中职工号为主码。 用SQL语言定义这两个关系模式,要求在模式中完成以下完整性约束条件的定义:
(1)定义每个模式的主码;(2)定义参照完整性;(3)定义职工年龄不得超过60岁。 答
将上述两个用汉字表示的关系模式对应转换为以下两个用符号表示的关系模式: DEPT(Deptno, Deptname, Manager, PhoneNumber) EMP(Empno,Ename,Age,Job,Sal,Deptno)
用SQL语言表示如下: CREATE TABLE DEPT (Deptno CHAR(4),
Deptname VARCHAR(20), Manager VARCHAR(10), PhoneNumber CHAR(12)
CONSTRAINT PK_SC PRIMARY KEY(Deptno));
CREATE TABLE EMP
(Empno CHAR (6) PRIMARY KEY, Ename VARCHAR(20), Age INT,
CONSTRAINT C1 CHECK(Age<=60), Job VARCHAR(10), Sal NUMERIC(7,2), Deptno CHAR(4),
CONSTRAINT FK_DEPTNO FOREIGN KEY(Deptno)
REFERENCES DEPT(Deptno));
3
正在阅读:
数据库系统概论CH5(部分)习题解答10-18
公司战略合作协议08-28
动土作业安全管理制度06-18
初中生物地理会考复习资料(人教版)03-08
湖南省邵阳县石齐学校八年级语文上学期期末考试试题 新人教版05-21
中考数学压轴题100题精选 - 图文07-03
内蒙古集宁一中(西校区)期末精选检测题(Word版 含答案)04-27
USSD精品营销门户业务规范(V1.0.0)报批稿050910-20
电工复习题03-15
中考英语试题解析版汇编之完形填空05-20
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 习题
- 概论
- 解答
- 部分
- 数据库
- 系统
- CH5
- 企业安全管理制度(标准版)
- 湖北省系统集成商名录2018版2592家 - 图文
- 正确去黑头的方法是什么
- 完整升级版人教版九年级化学下册全册教案(共多页)2
- 生理免疫考试及答案
- 从地缘政治角度浅论中日关系
- 中级汉语综合课 第十六课 话说“慢点儿”
- 中华人民共和国物权法(草案)(第二次审议稿)
- 5BM3U1signs 教案设计
- 课题成果公告 - 图文
- 期末复习材料力学大二下学期
- 51CTO下载-数据结构实验报告大全(严蔚敏版) - 图文
- 现代文学史教学大纲
- 三类人员安全生产知识考试报名登记表
- 网络选修课中国古代史考试题
- 课程设计题目
- 一年级数学(上)第四单元试卷(人教)
- 三段式电流保护整定计算实例
- 河北工业大学游戏实验1剖析
- 计算机软件毕业设计于C#语言和SQL Server数据库的宠物店管理系统 - 图文