如何恢复数据库到某一时间点的数据?

如何恢复数据库到某一时间点的数据?,第1张

恢复数据库到之前的某个时间点,必须要有日志备份

下面是一个使用日志的示例:

create database db1

go

alter database db1 set recovery full

go

backup database db1 to disk='db1.bak' with init--首先要对数据库进行全备份,否则checkpoint会阶段inactive的日志(类似于simple recovery)

go

use db1

go

create table t(col int)

go

---一些数据库 *** 作

---一些数据库 *** 作

---一些数据库 *** 作

--假设你在15点15分以后删除了这个表

drop table t

--如果想恢复这个表,需要对数据库进行日志备份

use master

go

backup log db1 to disk='db1.trn' with norecovery

go

---然后执行以下 *** 作

use master

go

restore database db1 from disk='db1.bak' with norecovery

go

restore log db1 from disk='db1.trn' with recovery,stopat='2009-03-08 15:15:00'--这时,数据库恢复到15:15的状态。

不知道你的数据库有没有设置 备份的选项。

前提条件

数据库的恢复模式(Recovery mode)为  “完整(Full)”

以前有 完整备份数据库

例如以前执行过

backup database test to disk='e:\test_20130704.dat'

下面是模拟一个  某段时间  误删数据, 需要恢复到错误删除之前的时间点的处理。

USE [test]

GO

-- 创建测试表

CREATE TABLE test_br_table (

  ID   int,

  VAL  VARCHAR(10),

  PRIMARY KEY(ID)

)

GO

INSERT INTO test_br_table  VALUES (1, 'TEST1')

INSERT INTO test_br_table  VALUES (2, 'TEST2')

INSERT INTO test_br_table  VALUES (3, 'TEST3')

GO

SELECT GETDATE()

GO

-----------------------

2013-07-04 16:44:12.393

(1 行受影响)

-- 假设误 *** 作, 删除所有的数据了.

DELETE FROM test_br_table

GO

(3 行受影响)

恢复  

USE [master]

GO

-- 步骤1. 备份当前数据库的事务日志:

BACKUP LOG [Test] TO disk= N'e:\test_log' WITH NORECOVERY

GO

已为数据库 'Test',文件 'Test_log' (位于文件 1 上)处理了 9 页。

BACKUP LOG 成功处理了 9 页,花费 0.046 秒(1.486 MB/秒)。

-- 步骤2. 恢复一个误删除之前的完全备份:

RESTORE DATABASE [Test] FROM DISK = N'e:\test_20130704.dat' WITH NORECOVERY,  REPLACE

GO

已为数据库 'Test',文件 'Test' (位于文件 1 上)处理了 376 页。

已为数据库 'Test',文件 'Test_log' (位于文件 1 上)处理了 3 页。

RESTORE DATABASE 成功处理了 379 页,花费 0.828 秒(3.574 MB/秒)。

-- 步骤3. 将数据库恢复至误删除之前的时间点:

RESTORE LOG [Test] FROM  DISK = N'e:\test_log' WITH  STOPAT = N'2013-07-04 16:44:12.393' , RECOVERY

GO

已为数据库 'Test',文件 'Test' (位于文件 1 上)处理了 0 页。

已为数据库 'Test',文件 'Test_log' (位于文件 1 上)处理了 9 页。

RESTORE LOG 成功处理了 9 页,花费 0.013 秒(5.258 MB/秒)。

 核对数据. 

use [Test]

GO

SELECT * FROM test_br_table

GO

ID          VAL

----------- ----------

          1 TEST1

          2 TEST2

          3 TEST3

(3 行受影响)

如果你的数据库的恢复模式(Recovery mode) 不是  “完整(Full)”

或者以前从来没有备份过数据库的话......

那么你可能需要去找找第三方的软件来恢复了......


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9883321.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存