sql 2008 怎么恢复某个时间段内误删的数据很急啊各种求大神支招用的delete删除的数据……

sql 2008 怎么恢复某个时间段内误删的数据很急啊各种求大神支招用的delete删除的数据……,第1张

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

前提条件
数据库的恢复模式(Recovery mode)为  “完整(Full)”
以前有 完整备份数据
例如以前执行过

backup database test to disk='e:\test_20130704dat'
下面是模拟一个  某段时间  误删数据, 需要恢复到错误删除之前的时间点的处理。


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:12393
(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 页,花费 0046 秒(1486 MB/秒)。
-- 步骤2 恢复一个误删除之前的完全备份:
RESTORE DATABASE [Test] FROM DISK = N'e:\test_20130704dat' WITH NORECOVERY,  REPLACE
GO
已为数据库 'Test',文件 'Test' (位于文件 1 上)处理了 376 页。
已为数据库 'Test',文件 'Test_log' (位于文件 1 上)处理了 3 页。
RESTORE DATABASE 成功处理了 379 页,花费 0828 秒(3574 MB/秒)。
-- 步骤3 将数据库恢复至误删除之前的时间点:
RESTORE LOG [Test] FROM  DISK = N'e:\test_log' WITH  STOPAT = N'2013-07-04 16:44:12393' , RECOVERY
GO
已为数据库 'Test',文件 'Test' (位于文件 1 上)处理了 0 页。
已为数据库 'Test',文件 'Test_log' (位于文件 1 上)处理了 9 页。
RESTORE LOG 成功处理了 9 页,花费 0013 秒(5258 MB/秒)。
 核对数据 
use [Test]
GO
SELECT  FROM test_br_table
GO
ID          VAL
----------- ----------
          1 TEST1
          2 TEST2
          3 TEST3
(3 行受影响)

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

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

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

以上就是关于sql 2008 怎么恢复某个时间段内误删的数据很急啊各种求大神支招用的delete删除的数据……全部的内容,包括:sql 2008 怎么恢复某个时间段内误删的数据很急啊各种求大神支招用的delete删除的数据……、、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存