以下对数据库故障的描述中,不正确的是(  )。A.系统故障指软硬件错误导致的系统

资格题库2022-08-02  45

问题 以下对数据库故障的描述中,不正确的是(  )。A.系统故障指软硬件错误导致的系统崩溃B.由于事务内部的逻辑错误造成该事务无法执行的故障属于事务故障C.可通过数据的异地备份来减少磁盘故障可能给数据库系统造成数据丢失D.系统故障一定会导致磁盘数据丢失

选项 A.系统故障指软硬件错误导致的系统崩溃
B.由于事务内部的逻辑错误造成该事务无法执行的故障属于事务故障
C.可通过数据的异地备份来减少磁盘故障可能给数据库系统造成数据丢失
D.系统故障一定会导致磁盘数据丢失

答案 D

解析 数据库故障
主要分:事务故障、系统故障和介质故障。
事务故障
是指事务在运行至正常终点前被终止,此时数据库可能出现不正确的状态。
由于事务程序内部错误而引起的,有些可以预期,如金额不足等;有些不可以预期,如非法输入、运算溢出等
恢复过程
①反向(从后向前)扫描日志文件,查找该事务的更新操作。
②对该事务的更新操作执行逆操作,也就是将日志记录更新前的值写入数据库。
③继续反向扫描日志文件,查找该事务的其他更新操作,并作同样处理。
④如此处理下去,直到读到了此事务的开始标记,事务故障恢复就完成了。
事务故障的恢复由系统自动完成,对用户是透明的。
系统故障(通常称为软故障)
是指造成系统停止运转的任何事件,使得系统要重新启动。
特定类型的硬件错误、操作系统故障、DBMS代码错误、突然停电等。
恢复过程
①正向(从头到尾)扫描日志文件,找出故障发生前已经提交的事务(这些事务既有BEGIN TRANSACTION记录,也有COMMIT记录),将其事务标识记入重做(REDO)队列。同时找出故障发生时尚未完成的事务(这些事务只有BEGIN TRANSACTION记录,无相应的COMMIT记录),将其事务标识记入撤销(UNDO)队列。
②反向扫描日志文件,对每个UNDO事务的更新操作执行逆操作,也就是将日志记录中更新前的值写入数据库。
③正向扫描日志文件,对每个REDO事务重新执行日志文件登记的操作,也就是将日志记录中更新后的值写入数据库。
是在系统重启之后自动执行的。
介质故障(称为硬件故障)
是指外存故障,例如磁盘损坏、磁头碰撞,瞬时强磁场干扰等。
这类故障将破坏数据库或部分数据库,并影响正在存取这部分数据的所有事务,日志文件也被破坏
恢复过程。
①装入最新的数据库后备副本,使数据库恢复到最近一次转储时的一致性状态。
②转入相应的日志文件副本,重做已完成的事务。
介质故障的恢复需要DBA的介入,具体的恢复操作仍由DBMS完成。
恢复过程
①DBA只需要重装最近转储的数据库副本和有关的各日志文件副本。
②然后执行系统提供的恢复命令。
转载请注明原文地址:https://www.tihaiku.com/congyezige/2419794.html

最新回复(0)