浅谈 SQLServer 数据库的备份与还原

2019-09-10 10:28:35 浏览数 (1)

在生活中,数据库管理员最担心的就是数据库瘫痪,从而造成数据丢失,任何数据的丢失都会造成非常严重的后果,所以我们为了更有效的保护和恢复数据,需要进行备份数据。 一般来说,造成数据的丢失主要包括几类: 1、程序错误:程序异常终止或逻辑错误 2、人为错误:管理员误操作 3、计算机失败:系统崩溃,硬件和软件引起的错误 4、磁盘失败:磁盘读写磁头损坏、磁盘物理块损坏 5、灾难和偷窃:自然灾害、人为偷窃都会造成 SQL server的备份有如下三种: 1、完整备份:完整备份包括对整个数据库、部分事务日志、数据库结构和文件结构的备份。它代表的是备份完成时刻的数据库。是所有备份类型的基础。

2、差异备份:是指对上一次完整备份之后所有更改的数据做备份,备份过程能够识别出数据库中哪一部分被修改了,并只对这一部分做备份。

差异备份的优势是速度快,备份数据库所需要的时间很少,但差异备份要求事先已经执行过一次完整备份。

3、事务日志备份:记录了数据库的所有改变,在备份事务日志时,需要考虑以下因素:

在执行了至少一次完整备份后,才能备份事务日志; 在简单恢复模式下不能备份事务日志; 如果没有与其相一致的数据库备份,则不能恢复事务日志。 在执行数据库事务日志备份期间,SQL server将做以下工作: 备份事务日志:从上一次成功的事务日志备份到当前事务日志的尾部; 截断事务日志:到事务日志活动部分的开始,丢弃不活动的部分。 事务日志备份主要是T-SQL语句,而不是整个数据库结构、文件结构或数据。 恢复模式也有三种: 1、简单恢复模式:在简单恢复模式下,不活动的日志将被删除,所以不支持事务日志备份。也正是因为不支持事务日志备份,数据库只能恢复到备份的时间点,而无法将数据库还原到故障点或特定的时间点。因此,简单恢复模式只适用于小型数据库和不经常改动的数据库。

2、完整恢复模式:对于十分重要的生产数据库,如银行、电信系统,在发生故障时可能要求恢复到历史上某个时刻,一旦发生故障,必须保证数据不丢失,保证数据能够恢复到发生故障的状态。这样,就必须采用完整恢复模式。

完整恢复模式可在最大范围内防止出现故障时丢失数据,它包括数据库备份和事务日志备份,并提供全面保护,使数据库免受媒体故障的影响。

由于支持事务日志备份,因此完整恢复模式可以将数据库恢复到任意一个指定的时间点。

3、大容量日志恢复模式: DBA在某些场合需要对数据库执行一些大批量的数据插入、更新或删除等操作,如一次需要导入上百万条数据,如果在完整恢复模式下,那么这些操作将产生大量的日志记录,导致数据库性能很低。在这种情况下,可以采用大容量日志恢复模式来提高性能。

虽然大容量日志恢复模式会完整的记录其他事务,但它只对大容量操作进行最小记录,只要日志备份包含大容量操作,数据库就只能恢复到日志备份的结尾,而不能恢复到某个时间点或日志备份中某个标记的事务。 备份设备: 在进行备份时,一般是建立一个文件来存储备份的数据,这个备份文件就叫做备份设备,如图中的backup就是创建的一个备份设备:

注意:若想创建自动备份,那么SQL server代理必须启用:

创建备份计划: 右击“维护计划”,点击“维护计划向导”即可根据向导来进行做备份计划:

勾选要执行的工作:

定义详细信息:

设置自动清除历史备份:

由于每天对数据库进行备份,时间久了,其备份文件占用的磁盘空间也越来越大,通过修改维护计划,可以

所有的备份设置,最好在初次备份时,进行全面的检查,以确保备份的万无一失。 备份完毕之后,查看备份文件:

这里我们删除数据库中的表来模拟数据库数据丢失

0 人点赞