数据库原理与应用考试试题及答案

上传人:宝路 文档编号:21981349 上传时间:2017-11-25 格式:DOCX 页数:7 大小:23.15KB
返回 下载 相关 举报
数据库原理与应用考试试题及答案_第1页
第1页 / 共7页
数据库原理与应用考试试题及答案_第2页
第2页 / 共7页
数据库原理与应用考试试题及答案_第3页
第3页 / 共7页
数据库原理与应用考试试题及答案_第4页
第4页 / 共7页
数据库原理与应用考试试题及答案_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《数据库原理与应用考试试题及答案》由会员分享,可在线阅读,更多相关《数据库原理与应用考试试题及答案(7页珍藏版)》请在金锄头文库上搜索。

1、1. 消除了非主属性对码的部分函数依赖的 1NF 的关系模式,必定是( ) 。A. 1NF B. 2NF C. 3NF D. BCNF2 .下列关于数据库恢复说法不正确的是( )A.事物故障恢复采用日志文件 B.系统故障恢复采用日志文件C.介质故障恢复采用日志文件 D.以上故障恢复均不采用日志文件3. 下面( )不是常用的数据模型?A. 关系模型 B. 线性模型 C. 层次模型 D. 网状模型4 .在数据库设计中,将 E-R 图转换成关系数据模型的过程属于( )A.需求分析阶段 B.概念设计阶段 C.逻辑设计阶段 D.物理设计阶段 5 .DBMS 中实现事务持久性的子系统是( )A.安全性管理

2、子系统 B.完整性管理子系统 C.并发控制子系统 D.恢复管理子系统 6.数据库与文件系统的根本区别在于( )A.提高了系统效率 B.方便了用户使用 C.数据的结构化 D.节省了存储空间 7. SQL 语言是( )的语言,容易学习 。A.过程化 B. 非过程化C.格式化 D. 导航式8 为了防止一个用户的工作不适当地影响另一个用户,应该采取( ) 。A. 完整性控制 B. 访问控制C. 安全性控制 D. 并发控制9 DBMS 普遍采用( )方法来保证调度的正确性 。A. 索引 B. 授权 C. 封锁 D. 日志10事务 T 在修改数据 R 之前必须先对其加 X 锁,直到事务结束才释放,这是(

3、) 。A. 一级封锁协议 B. 二级封锁协议 C. 三级封锁协议 D. 零级封锁协议11. 下面的选项不是关系数据库基本特征的是( )。A.不同的列应有不同的数据类型 B.不同的列应有不同的列名C.与行的次序无关 D.与列的次序无关12. 关系模型中实现实体间 N:M 联系是通过增加一个( ) 。A.关系实现 B. 属性实现 C. 关系或一个属性实现 D. 关系和一个属性实现13. 关系代数运算是以( )为基础的运算 。A. 关系运算 B. 谓词演算 C. 集合运算 D. 代数运算14. 数据库设计可划分为七个阶段,每个阶段都有自己的设计内容,“为哪些关系,在哪些属性上、键什么样的索引”这一设

4、计内容应该属于( )设计阶段。A. 概念设计 B. 逻辑设计 C. 物理设计 D. 全局设计15SQL 语言中的 COMMIT 语句的主要作用是( )。A. 结束程序 B. 返回系统 C. 提交事务 D. 存储数据16一个事务的执行,要么全部完成,要么全部不做,一个事务中对数据库的所有操作都是一个不可分割的操作序列的属性是( ) 。A. 原子性 B. 一致性 C. 独立性 D. 持久性17.关系的主属性不能取空值,属于( )A. 实体完整性约束 B.参照完整性约束C. 用户定义完整性约束 D. 动态元组约束 18.如果一个关系属于第 3 范式,则它( )A. 必然属于 2NF B. 必然属于

5、4NFC. 可能不属于 2NF D. 必然属于 BCNF19.SQL 语言集几个功能模块为一体,其中不包括( )A. DDL B. DML C. DCL D. DNL20.数据的物理独立性是由( )映射所支持的A. 外模式 /模式 B. 外模式/内模式C. 模式/内模式 D. 子模式/逻辑模式.B 2.C 3.B 4.C 5.D 6.C 7.C 8.D 9.C 10.A11.A 12.A 13.A -不太确定 14.B 15.C 16.A 17.B 18.A 19.D 20.C1.试述事务的概念及事务的四个特性。答:事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割

6、的工作单位。事务具有四个特性:原子性(Atomicity) 、一致性(Consistency) 、隔离性(Isolation)和持续性(Durability) 。这个四个特性也简称为 ACID 特性。 原子性:事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。一致性:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。隔离性:一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他并发事务是隔离的,并发执行的各个事务之间不能互相干扰。持续性:持续性也称永久性(Permanence) ,指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接

7、下来的其他操作或故障不应该对其执行结果有任何影响。2.为什么事务非正常结束时会影响数据库数据的正确性,请列举一例说明之。答:事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。如果数据库系统运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。例如某工厂的库存管理系统中,要把数量为 Q 的某种零件从仓库 1 移到仓库2 存放。则可以定义一个事务 T,T 包括两个操作;Q1=Q1-Q,Q2=Q2+Q。如果 T 非正常终止时只做了第一个操作,则数据库就处于不一致性状态,库存量无缘无

8、故少了 Q。3.数据库中为什么要有恢复子系统?它的功能是什么?答:因为计算机系统中硬件的故障、软件的错误、操作员的失误以及恶意的破坏是不可避免的,这些故障轻则造成运行事务非正常中断,影响数据库中数据的正确性,重则破坏数据库,使数据库中全部或部分数据丢失,因此必须要有恢复子系统。恢复子系统的功能是:把数据库从错误状态恢复到某一已知的正确状态(亦称为一致状态或完整状态) 。4数据库运行中可能产生的故障有哪几类?哪些故障影响事务的正常执行?哪些故障破坏数据库数据?答:数据库系统中可能发生各种各样的故障,大致可以分以下几类:(1)事务内部的故障;(2)系统故障;(3)介质故障;(4)计算机病毒。事务故

9、障、系统故障和介质故障影响事务的正常执行;介质故障和计算机病毒破坏数据库数据。5据库恢复的基本技术有哪些? 答:数据转储和登录日志文件是数据库恢复的基本技术。当系统运行过程中发生故障,利用转储的数据库后备副本和日志文件就可以将数据库恢复到故障前的某个一致性状态。6. 数据库转储的意义是什么? 试比较各种数据转储方法。答:数据转储是数据库恢复中采用的基本技术。所谓转储即 DBA 定期地将数据库复制到磁带或另一个磁盘上保存起来的过程。当数据库遭到破坏后可以将后备副本重新装入,将数据库恢复到转储时的状态。静态转储:在系统中无运行事务时进行的转储操作。静态转储简单,但必须等待正运行的用户事务结束才能进

10、行。同样,新的事务必须等待转储结束才能执行。显然,这会降低数据库的可用性。动态转储:指转储期间允许对数据库进行存取或修改。动态转储可克服静态转储的缺点,它不用等待正在运行的用户事务结束,也不会影响新事务的运行。但是,转储结束时后援副本上的数据并不能保证正确有效。因为转储期间运行的事务可能修改了某些数据,使得后援副本上的数据不是数据库的一致版本。为此,必须把转储期间各事务对数据库的修改活动登记下来,建立日志文件(log file) 。这样,后援副本加上日志文件就能得到数据库某一时刻的正确状态。转储还可以分为海量转储和增量转储两种方式。海量转储是指每次转储全部数据库。增量转储则指每次只转储上一次转

11、储后更新过的数据。从恢复角度看,使用海量转储得到的后备副本进行恢复一般说来更简单些。但如果数据库很大,事务处理又十分频繁,则增量转储方式更实用更有效。7. 什么是日志文件?为什么要设立日志文件?答:(1)日志文件是用来记录事务对数据库的更新操作的文件。(2)设立日志文件的目的是: 进行事务故障恢复;进行系统故障恢复;协助后备副本进行介质故障恢复。8. 登记日志文件时为什么必须先写日志文件,后写数据库?答:把对数据的修改写到数据库中和把表示这个修改的日志记录写到日志文件中是两个不同的操作。有可能在这两个操作之间发生故障,即这两个写操作只完成了一个。如果先写了数据库修改,而在运行记录中没有登记这个

12、修改,则以后就无法恢复这个修改了。如果先写日志,但没有修改数据库,在恢复时只不过是多执行一次 UNDO 操作,并不会影响数据库的正确性。所以一定要先写日志文件,即首先把日志记录写到日志文件中,然后写数据库的修改。9. 针对不同的故障,试给出恢复的策略和方法。 (即如何进行事务故障的恢复?系统故障的恢复?介质故障恢复?) 答:事务故障的恢复:事务故障的恢复是由 DBMS 自动完成的,对用户是透明的。DBMS 执行恢复步骤是:(1)反向扫描文件日志(即从最后向前扫描日志文件) ,查找该事务的更新操作。(2)对该事务的更新操作执行逆操作。即将日志记录中“更新前的值”写入数据库。(3)继续反向扫描日志

13、文件,做同样处理。(4)如此处理下去,直至读到此事务的开始标记,该事务故障的恢复就完成了。答:系统故障的恢复:系统故障可能会造成数据库处于不一致状态:一是未完成事务对数据库的更新可能已写入数据库;二是已提交事务对数据库的更新可能还留在缓冲区,没来得及写入数据库。因此恢复操作就是要撤销(UNDO)故障发生时未完成的事务,重做(REDO)已完成的事务。系统的恢复步骤是:(1)正向扫描日志文件,找出在故障发生前已经提交的事务队列(REDO 队列)和未完成的事务队列(UNDO 队列) 。(2)对撤销队列中的各个事务进行 UNDO 处理。进行 UNDO 处理的方法是,反向扫描日志文件,对每个 UNDO

14、事务的更新操作执行逆操作,即将日志记录中“更新前的值” (Before Image)写入数据库。(3)对重做队列中的各个事务进行 REDO 处理。进行 REDO 处理的方法是:正向扫描日志文件,对每个 REDO 事务重新执行日志文件登记的操作。即将日志记录中“更新后的值” (After Image)写入数据库。*解析:在第(1)步中如何找出 REDO 队列和 UNDO 队列?请大家思考一下。下面给出一个算法:1) 建立两个事务队列: UNDO-LIST: 需要执行 undo 操作的事务集合; REDO-LIST: 需要执行 redo 操作的事务集合;两个事务队列初始均为空。2) 从日志文件头开

15、始,正向扫描日志文件 如有新开始(遇到 Begin Transaction)的事务 Ti,把 Ti 暂时放入 UNDO-LIST 队列; 如有提交的事务(遇到 End Transaction)Tj ,把 Tj 从 UNDO-LIST 队列移到REDO-LIST 队列;直到日志文件结束答: 介质故障的恢复:介质故障是最严重的一种故障。恢复方法是重装数据库,然后重做已完成的事务。具体过程是:(1)DBA 装入最新的数据库后备副本(离故障发生时刻最近的转储副本) ,使数据库恢复到转储时的一致性状态。(2)DBA 装入转储结束时刻的日志文件副本(3)DBA 启动系统恢复命令,由 DBMS 完成恢复功能

16、,即重做已完成的事务。*解析1)我们假定采用的是静态转储,因此第(1)步装入数据库后备副本便可以了。2)如果采用的是静动态转储,第(1)步装入数据库后备副本还不够,还需同时装入转储开始时刻的日志文件副本,经过处理后才能得到正确的数据库后备副本。3)第(2)步重做已完成的事务的算法是:a. 正向扫描日志文件,找出故障发生前已提交的事务的标识,将其记入重做队列b. 再一次正向扫描日志文件,对重做队列中的所有事务进行重做处理。即将日志记录中“更新后的值”写入数据库。10. 具有检查点的恢复技术有什么优点?答:利用日志技术进行数据库恢复时,恢复子系统必须搜索日志,确定哪些事务需要 REDO,哪些事务需要 UNDO。一般来说,需要检查所有日志记录。这样做有两个问题:一是搜索整个日志将耗费大量的时间。二是很多需要 REDO 处理的事务实际上

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 试题/考题

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号