SQL Server 数据恢复到指点时间点(完整恢复)

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
日志服务 SLS,月写入数据量 50GB 1个月
简介:

说到数据库恢复,其实我们一般最常见的有两种,一种就是简单恢复,通过备份的bak文件直接恢复数据库,缺点就是有可能数据丢失。另外一种就是通过备份的数据+事务日志还原数据。但是后者还原的话我们需要保证事务日志的完整性。我们今天就主要介绍的是第二种,所有的操作过程我们使用的是SSMS进行操作的。

注:使用第二种方法还原数据的时候需要注意的问题:1、要准备好之前的完整备份的数据,2、备份全新的事务日志。3、通过完整备份的数据进行完整还原。4、通过备份的全新的事务日志进行指定时间点的数据还原。

我们首先创建一个测试数据库---DB2,然后创建一个表info

定义字段信息

clipboard

我们插入数据

1
2
3
4
select  * from info
insert into info(idcode,age)values( 'zs' ,18)
insert into info(idcode,age)values( 'ls' ,20)
insert into info(idcode,age)values( 'gwl' ,27)

clipboard

接下来我们备份数据,备份路劲D:\DB_BACKUP

右击数据库---任务--备份

clipboard

备份类型:完整。

备份路劲:D:\db_backup\db2.bak

clipboard

备份完成

clipboard

备份完成的文件

clipboard

成功备份后,我们增加几条数据,然后删除几条数据(我们需要注意时间点,方便后面的操作)

此时就当是我们误操作结果;误操作后,我们正常还原了就可以了

需要注意的是,输入的写入和删除有可能是不同的用户进行操作的,所以 通过还原肯定是数据丢失了,所以我们通过完全备份恢复完成后,还需要通过log进行还原。

当前时间时21:32

clipboard

我们插入了几条数据

1
2
3
4
select  * from info
insert into info(idcode,age)values( 'xll' ,118)
insert into info(idcode,age)values( 'wc' ,210)
insert into info(idcode,age)values( 'lc' ,127)

clipboard

我们在过几分钟进行数据删除--删除2两条测试数据

当前时间为:

clipboard

接下来我们删除两条数据

1
2
3
select  * from info
delete info where idcode =  'ls'
delete info where idcode =  'gwl'

clipboard

此时我们发现数据有异常所以需要通过备份进行还原。但是我们的备份之后,做了一些数据的插入,如果用之前备份的恢复的话,数据肯定有丢失,所以我们还需要借助日志进行还原。

所以我们需要通过完整备份进行恢复,然后通过log进行恢复,然后恢复到指定的时间点。

在恢复完整备份之前,我们需要进行一次全新的事务日志备份。

其实备份事务日志的目录是为了将其写入截断,保证数据的完整性

clipboard

数据库---右击--任务---备份---备份类型--事务日志

clipboard

备份成功后

clipboard

此时我们需要通过完整备份进行还原以下数据

数据库---任务---还原--数据库

clipboard

选择设备---浏览备份的数据库文件

clipboard

记住,我们一定要在选项中选择 norecovery   
恢复状态:RESTORE WITH NORECOVERY

clipboard

开始还原提示以下信息:

clipboard

我们也可以使用以下脚本进行还原

1
2
3
4
USE [master]
BACKUP LOG [DB2] TO DISK = N 'D:\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\Backup\DB2_LogBackup_2017-03-19_22-40-40.bak'  WITH NOFORMAT, NOINIT, NAME = N 'DB2_LogBackup_2017-03-19_22-40-40' , NOSKIP, NOREWIND, NOUNLOAD, NORECOVERY , STATS = 5
RESTORE DATABASE [DB2] FROM DISK = N 'D:\DB_BACKUP\DB2.bak'  WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 5
GO

出现以上问题,我们有两种解决方法

1、还原数据库时,点击选择页上的选项,勾选覆盖现有数据库(WITH REPLACE),点确定后即可成功还原数据库(推荐此方法)。

0-365228085

2、进行还原操作时,点击选择页上的选项,勾选保持源数据库处于正在还原状态(BACKUP LOG WITH NORECOVERY),即可解决问题。

clipboard

我们选择第二种方法可以正常恢复成功

clipboard

此时我们查看到数据库一直再提示---正在还原中,该现象为正常的。

clipboard

接下来我们要通过事务日志进行数据还原。

数据库---任务---还原---事务日志

clipboard

浏览到保存的事务日志文件—DB2.trn

clipboard

然后我们需要选择删除数据的日期及时间:我们上面记载了删除数据的日期及时间 21:36

此时是恢复数据的主要关键地方。

clipboard

确认的时间点信息

clipboard

我们此时需要单击选项菜单:

恢复状态:回滚未提交的事务,使用数据库处理可以使用的状态。无法还原其他事务日志(RESTORE WITH RECOVERY)

image

我们也可以通过脚本进行数据还原。

1
2
RESTORE LOG [DB2] FROM DISK = N 'D:\DB_BACKUP\DB.trn'  WITH FILE = 1, NOUNLOAD, STATS = 10, STOPAT = N '2017-03-19T21:36:01'
GO

clipboard

还原成功后,数据库状态显示正常

clipboard

接下来我们查看数据,恢复正常了;

clipboard




本文转自 高文龙 51CTO博客,原文链接:http://blog.51cto.com/gaowenlong/1908376,如需转载请自行联系原作者

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
4月前
|
SQL 数据库
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库。 SQL Server数据库出现823错误的可能原因有:数据库物理页面损坏、数据库物理页面校验值损坏导致无法识别该页面、断电或者文件系统问题导致页面丢失。
124 12
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
|
12天前
|
数据库 Windows
SqlServer数据恢复—SqlServer数据库所在分区损坏的数据恢复案例
一块硬盘上存放的SqlServer数据库,windows server操作系统+NTFS文件系统。由于误操作导致分区损坏,需要恢复硬盘里的SqlServer数据库数据。
|
5月前
|
SQL 存储 关系型数据库
【MySQL核心】MySQL 数据恢复-ibd2sql
【MySQL核心】MySQL 数据恢复-ibd2sql
|
3月前
|
存储 数据挖掘 数据库
数据库数据恢复—SQLserver数据库ndf文件大小变为0KB的数据恢复案例
一个运行在存储上的SQLServer数据库,有1000多个文件,大小几十TB。数据库每10天生成一个NDF文件,每个NDF几百GB大小。数据库包含两个LDF文件。 存储损坏,数据库不可用。管理员试图恢复数据库,发现有数个ndf文件大小变为0KB。 虽然NDF文件大小变为0KB,但是NDF文件在磁盘上还可能存在。可以尝试通过扫描&拼接数据库碎片来恢复NDF文件,然后修复数据库。
|
4月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
6月前
|
SQL 小程序 数据库
数据库数据恢复—SqlServer数据库无法被读取的数据恢复案例
SQL Server数据库的数据无法被读取。 经过数据库数据恢复工程师的初步检测,发现SQL Server数据库文件无法被读取的原因是底层File Record被截断为0,无法找到文件开头,而且数据表结构也已经损坏。镜像文件的前几十M和中间一部分空间被覆盖,系统表损坏,所以无法读取。
数据库数据恢复—SqlServer数据库无法被读取的数据恢复案例
|
6月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
163 13
|
6月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
6月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
87 6
|
6月前
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
545 1