首页 养生问答 疾病百科 养生资讯 女性养生 男性养生

如何使用事务日志恢复sql server数据库

发布网友 发布时间:2022-04-22 00:14

我来回答

2个回答

懂视网 时间:2022-05-02 05:14

-- 使用前 请修改 老的数据库名称 目前用的是 OIOrg.dbo   AM8.dbo  OIFile.dbo  DMS.dbo
declare @OIOrgDBVer varchar(40)
declare @AMDBVer varchar(40)
declare @OIFileDBVer varchar(40)
declare @DMSDBVer varchar(40)
select @OIOrgDBVer = ‘OIOrgDB    ‘ +(select S_C1  from OIOrg.dbo.OI_ORG_DBVER) + ‘   New- 20170327‘
select @AMDBVer  = ‘AM8DB      ‘ +(select S_C1  from AM8.dbo.OI_STK_DBVER) + ‘   New- 20170509‘
select @OIFileDBVer  = ‘OIFileDB   ‘ +(select S_C1  from OIFile.dbo.OI_FILE_DBVER) + ‘   New- 20151106‘
select @DMSDBVer  = ‘DMSDB      ‘ +(select S_C1  from DMS.dbo.OI_DMS_DBVER) + ‘   New- 20170601‘
print ‘列出目前所有数据库版本日期‘
print @OIOrgDBVer
print @AMDBVer
print @OIFileDBVer
print @DMSDBVer

sql脚本判断AM及Mobox的数据库版本

标签:数据库名   bsp   var   版本   new   declare   print   file   led   

热心网友 时间:2022-05-02 02:22

恢复过程

以数据库恢复模式设为FULL为例:

恢复过程的第一步是执行尾日志备份,(BACKUP LOG Student TO DISK='E:\stulog.dmp'   ) 。

在恢复一个数据库之前,为保证上次备份之后发生改变的记录都包含在恢复过程之中,需要执行这种类型的备份。

下一步,查找数据库备份文件在机器或网络中的存储位置。

如果要在另一台服务器上恢复数据库,最好是把这些文件复制到目标服务器中。在备份文件所在的位置,找出最后一个完整的数据库备份(这些文件通常使用.bak为扩展名);恢复这个完整的备份。


下面的脚本将完整的备份文件应用于NewDatabase数据库:

RESTORE DATABASE NewDatabase
FROM DISK = 'D: BackupFilesTestDatabaseFullBackup.bak'
WITH
MOVE 'PreviousDatabase' TO 'D:DataFiles TestDatabase.mdf',
MOVE 'PreviousDatabase_log' TO 'D:DataFiles TestDatabase_Log.ldf',
NORECOVERY

这段脚本指出完整备份文件位于服务器的D盘中,你正在使用备份文件恢复NewDatabase这个数据库。

脚本中的语句将数据文件和日志文件从完整备份文件转移到TestDatabase数据库的新文件中。脚本中的最后一个语句——NORECOVERY——非常重要。

NORECOVERY模式有三种选项,如下所示:

一旦你使用NORECOVERY选项恢复了完整备份,你可以开始应用事务日志备份或差异备份。

差异备份

差异备份是指对上次完整数据库备份后数据库发生的任何改变进行备份。如果有几个差异备份,只需要恢复最后一个备份文件。在这种情况下,并不存在差异备份,因此可以直接转向事务日志备份。

事务日志备份

事务日志备份保留上次事务日志备份后发生的所有事务的痕迹;它还允许把数据库恢复到数据库发生错误之前的一个时间点。事务日志备份按顺序发生,从而建立一个备份链。在把一连串事务日志备份恢复到一个时间点时,事务日志文件也必须按顺序恢复。

当使用一个数据库维护计划来建立事务日志备份时,事务日志文件名中往往包含一个时间指示器。

下面的脚本使用NORECOVERY选项应用三个事务日志备份,最后一个语句把数据库恢复到最后一个事务日志文件的结束点。

RESTORE LOG NewDatabase
FROM DISK = ''D: BackupFilesTestDatabase_TransactionLogBackup1.trn'
WITH NORECOVERY
RESTORE LOG NewDatabase
FROM DISK = ''D: BackupFiles TestDatabase_TransactionLogBackup2.trn'
WITH NORECOVERY
RESTORE LOG NewDatabase
FROM DISK = ''D: BackupFiles TestDatabase_TransactionLogBackup3.trn'
WITH NORECOVERY
RESTORE LOG NewDatabase
FROM DISK = ''D: BackupFiles TestDatabase_TransactionLogBackup4.trn'
WITH RECOVERY

恢复到一个时间点

在上面的例子中,把数据库恢复到最后一个事务日志的结束点。

如果想把数据库恢复到事务日志结束前的某个特定的时间点,必须使用STOPAT选项。

下面的脚本把日志序列中的第四个事务日志恢复到4:01 AM——正好在数据库出错之前。

RESTORE LOG NewDatabase
FROM DISK = ''D: BackupFiles TestDatabase_TransactionLogBackup4.trn'
WITH STOPAT = N'6/28/2007 4:01:45 PM', RECOVERY

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