SQL Server LOG数据恢复

发布于 2024-08-04 04:22:17 字数 117 浏览 10 评论 0原文

我想知道如何从日志文件中恢复数据。 我正在使用 sql 2005(完整备份)。

问题是昨晚有一项服务清除了我的数据(它不应该清除)。 现在我想恢复之前删除的那些行。

谁能告诉我我该怎么做?

I was wondering how you can recover data from your logfile.
I'm using sql 2005 (full backup).

The problem is that a service cleared my data last night (which it shouldn't have).
and now I want to recover those rows that were deleted before.

can anyone tell me how I can do this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

椒妓 2024-08-11 04:22:18

只要您有删除之前的数据库备份,以及自上次数据库备份以来所做的所有事务日志备份,那么您就能够恢复到某个时间点。

首先要做的是备份事务日志。

然后,您将上次数据库备份以及此后的所有事务日志备份恢复到删除之前的时间点。

请参阅这篇 MSDN 文章了解如何执行此操作。

我建议您将现有数据库保留原样,并将备份恢复到新数据库。然后,您可以编写一些脚本将所需的数据传输回实时数据库。

As long as you have a backup of your database from before the delete and then all transaction log backups that have been made since the last database backup then you will be able to restore to a point in time.

The first thing to do is take a backup of the transaction log.

Then you restore your last database backup and all transaction log backups since then up to the point in time just before the delete.

See this MSDN Article on how to do it.

I would suggest that you leave your existing database in place as it is and restore the backups to a new database. Then you can write some scripts to transfer the required data back into your live database.

梦里梦着梦中梦 2024-08-11 04:22:18

首先,您的数据库必须处于完整恢复模式,并且您必须拥有完整的事务日志备份链 - 一系列具有不间断的日志序列号 (LSN) 序列的日志记录。

日志备份链在完全恢复时启动。进行数据库备份或恢复模式从SIMPLE切换到FULL并进行完整备份。之后,定期创建事务日志备份。日志备份链只能通过两种方式中断:

  • 覆盖备份集
  • 从 FULL 切换到 SIMPLE 或 BULK LOGGED 恢复模式

中断日志备份链可能会导致事务信息丢失

您可以使用以下命令恢复到某个时间点:

  • SQL Server Management Studio,如 Robin 提供的链接所示
  • 使用 T-SQL 和 STOPAT 选项

语法

RESTORE LOG database_name 
FROM <backup_device> 
WITH STOPAT = time, RECOVERY… 
  • 使用第三方工具,例如 ApexSQL Log,它不仅可以恢复到特定时间点,还可以有选择地仅回滚您选择的

事务可以在此处找到所有列出的选项的步骤:恢复数据库到某个时间点

免责声明:我在 ApexSQL 担任支持工程师

First of all, your database must be in the full recovery model and you must have a full chain of transaction log backups - a series of log records having an unbroken sequence of log sequence numbers (LSNs)

The log backup chain is started when a full database backup is made or the recovery model is switched from SIMPLE to FULL and a full backup is made. After that, transaction log backups are created on regular basis. The log backup chain can be broken only in two ways:

  • Overwriting the backup set
  • Switching from FULL to SIMPLE or BULK LOGGED recovery models

Breaking the log backup chain can lead to missing transaction information

You can restore to a point in time using:

  • SQL Server Management Studio, as shown in the link Robin provided
  • Using T-SQL and the STOPAT option

Syntax

RESTORE LOG database_name 
FROM <backup_device> 
WITH STOPAT = time, RECOVERY… 
  • Use a third party tool, such as ApexSQL Log which can not only restore to a specific point in time, but selectively roll back only the transdactions you selected

You can find the steps for all listed options here: Restore a database to a point in time

Disclaimer: I work for ApexSQL as a Support engineer

暖风昔人 2024-08-11 04:22:18

仅在以下情况下才能恢复您的数据:
1)数据库采用完全恢复模式;
2)您有意外删除之前所做的完整备份;
3) 您还没有再次恢复或备份该数据库。

如果这是正确的,您应该:
1) 进行事务日志备份;
2) 使用 NORECOVERY 选项从完整备份恢复数据库;
3) 使用 STOPAT 选项恢复事务日志。

Your data can be recovered only in case:
1) database uses full recovery model;
2) you have full backup that you make before accidental deleting;
3) you have have NOT recover or backup again this database yet.

If this is correct, you should:
1) make transaction log backup;
2) restore database from full backup WITH NORECOVERY option;
3) restore transaction log using STOPAT option.

客…行舟 2024-08-11 04:22:18

要将事务日志文件恢复到某个时间点,您的数据库必须在完全恢复模式下运行。因此,首先您必须还原最新的完整数据库备份:

RESTORE DATABASE *database* FROM DISK = 'D:/Full.bak' WITH NORECOVERY, REPLACE

下一步是还原最后一个差异数据库备份:

RESTORE DATABASE *database* FROM DISK = 'D:/Diff.bak' WITH NORECOVERY

然后以正确的顺序还原自上次差异备份以来所做的所有事务日志备份

RESTORE LOG *database* FROM DISK = 'D:/log1.bak' WITH NORECOVERY
RESTORE LOG *database* FROM DISK = 'D:/log2.bak' WITH NORECOVERY
RESTORE LOG *database* FROM DISK = 'D:/log3.bak' WITH NORECOVER

最后一个事务日志备份必须是Restored 是在发生故障后使用 stopat 选项进行的事务日志备份。在 stopat 选项之后,您应该设置要恢复数据库的时间。

RESTORE LOG *database* FROM DISK = 'D:/log4.bak' WITH STOPAT = '2015-11-26 16:22:40.000', RECOVERY

To restore transaction log files to a point-in-time your database must run under full recovery model. So firstly you have to restore the latest full database backup:

RESTORE DATABASE *database* FROM DISK = 'D:/Full.bak' WITH NORECOVERY, REPLACE

The next step is to restore the last differential database backup:

RESTORE DATABASE *database* FROM DISK = 'D:/Diff.bak' WITH NORECOVERY

And then restore all transaction log backups that have made since last differential backup in correct sequence

RESTORE LOG *database* FROM DISK = 'D:/log1.bak' WITH NORECOVERY
RESTORE LOG *database* FROM DISK = 'D:/log2.bak' WITH NORECOVERY
RESTORE LOG *database* FROM DISK = 'D:/log3.bak' WITH NORECOVER

The last one transaction log backup that must be restored is the transaction log backup that have been made after the failure occurred with stopat option. After stopat option, you should set up the time to which you want to restore your database.

RESTORE LOG *database* FROM DISK = 'D:/log4.bak' WITH STOPAT = '2015-11-26 16:22:40.000', RECOVERY
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文