下面是一个使用日志的示例:
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)”
或者以前从来没有备份过数据库的话......
那么你可能需要去找找第三方的软件来恢复了......
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)