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

发布网友 发布时间:2022-04-26 18:13

我来回答

3个回答

热心网友 时间:2023-10-20 10:16

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


前提条件

数据库的恢复模式(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)”

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


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

追问能加个Q详细聊聊吗?我执行的时候遇到问题了……七,七,九,二,五,四,一,①,七

热心网友 时间:2023-10-20 10:16

可以明确的告诉你,如果没有备份,这条数据已经永远丢失了。以我的工作经验来看我们每半天备份一次数据,半天内丢失的就没了。delete掉的也没了,只能看log日志中谁删除的而已。

热心网友 时间:2023-10-20 10:17

用各种数据恢复软件即可。。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
0.538880s