数据库中为什么要有恢复子系统?它的功能是什么?

来源:互联网 发布:alpine linux 包管理 编辑:程序博客网 时间:2024/04/29 15:32

因为计算机系统中硬件的故障、软件的错误、操作员的失误以及恶意的破坏是不可避免的,这些故障轻则造成运行事务非正常中断,影响数据库中数据的正确性,重则破坏数据库,使数据库中全部或部分数据丢失,因此必须要有恢复子系统。

  恢复子系统的功能是:把数据库从错误状态恢复到某一已知的正确状态(亦称为一致状态或完整状态)。

 

数据库运行中可能产生的故障有哪几类?哪些故障影响事务的正常执行?哪些故障破坏数据库数据?

  答:数据库系统中可能发生各种各样的故障,大致可以分以下几类:

  (1)事务内部的故障;

  (2)系统故障;

  (3)介质故障;

  (4)计算机病毒。

 

5.据库恢复的基本技术有哪些?

  数据转储和登录日志文件是数据库恢复的基本技术。

  当系统运行过程中发生故障,利用转储的数据库后备副本和日志文件就可以将数据库恢复到故障前的某个一致性状态。

  6. 什么是日志文件?为什么要设立日志文件?

  答:(1)日志文件是用来记录事务对数据库的更新操作的文件。

  (2)设立日志文件的目的是: 进行事务故障恢复;进行系统故障恢复;协助后备副本进行介质故障恢复。

   7. 登记日志文件时为什么必须先写日志文件,后写数据库?

  答:把对数据的修改写到数据库中和把表示这个修改的日志记录写到日志文件中是两个不同的操作。有可能在这两个操作之间发生故障,即这两个写操作只完成了一个。

  如果先写了数据库修改,而在运行记录中没有登记这个修改,则以后就无法恢复这个修改了。如果先写日志,但没有修改数据库,在恢复时只不过是多执行一次UNDO操作,并不会影响数据库的正确性。所以一定要先写日志文件,即首先把日志记录写到日志文件中,然后写数据库的修改。

原创粉丝点击