我正在尝试将数据库从磁盘恢复到最新备份。备份中有四个备份集。我想恢复最新的备份集(今天备份的)。我需要能够使用 TSQL 来完成此操作。
下面的脚本有效:
RESTORE DATABASE DatabaseName
FROM DISK = 'D:\Data\DatabaseName.bak' WITH FILE = 4, REPLACE
然而,随着更多备份的进行,文件位置将来将发生变化。
有没有办法将备份恢复到文件位置而不指定确切的文件编号?类似“WITH FILE = most_recent_backup”
答案1
该RESTORE HEADERONLY
命令将为您提供文件中所有备份集的数据列表。从那里您可以选择最大值Position
并将其传递给FILE
参数。
答案2
不要将所有备份都放入一个文件中。如果这样做,并且该文件损坏,那么您就丢失了所有备份。
相反,当您使用 BACKUP DATABASE 和 RESTORE DATABASE 命令时,使用动态文件名将每个备份放入其自己的文件中。
答案3
Matt 的回答让我找到了正确的方向。我需要先存储结果集,然后才能选择最大位置。我的搜索让我找到了这个解决方案http://sqlforums.windowsitpro.com/web/forum/messageview.aspx?catid=74&threadid=93926&enterthread=y
set nocount on
Create Table #header (
BackupName nvarchar(128),
BackupDescription nvarchar(255),
BackupType smallint,
ExpirationDate datetime,
Compressed bit,
Position smallint,
DeviceType tinyint,
UserName nvarchar(128),
ServerName nvarchar(128),
DatabaseName nvarchar(128),
DatabaseVersion int,
DatabaseCreationDate datetime,
BackupSize numeric(20,0),
FirstLSN numeric(25,0),
LastLSN numeric(25,0),
CheckpointLSN numeric(25,0),
DatabaseBackupLSN numeric(25,0),
BackupStartDate datetime,
BackupFinishDate datetime,
SortOrder smallint,
CodePage smallint,
UnicodeLocaleId int,
UnicodeComparisonStyle int,
CompatibilityLevel tinyint,
SoftwareVendorId int,
SoftwareVersionMajor int,
SoftwareVersionMinor int,
SoftwareVersionBuild int,
MachineName nvarchar(128),
Flags int,
BindingID uniqueidentifier,
RecoveryForkID uniqueidentifier,
Collation nvarchar(128),
FamilyGUID uniqueidentifier,
HasBulkLoggedData bit,
IsSnapshot bit,
IsReadOnly bit,
IsSingleUser bit,
HasBackupChecksums bit,
IsDamaged bit,
BeginsLogChain bit,
HasIncompleteMetaData bit,
IsForceOffline bit,
IsCopyOnly bit,
FirstRecoveryForkID uniqueidentifier,
ForkPointLSN numeric(25,0) NULL,
RecoveryModel nvarchar(60),
DifferentialBaseLSN numeric(25,0) NULL,
DifferentialBaseGUID uniqueidentifier,
BackupTypeDescription nvarchar(60),
BackupSetGUID uniqueidentifier NULL
)
insert #header
Exec ('restore headeronly from disk = ''\\pathToBackup\file.bak''')
select backupstartdate from #header
drop table #header