Восстановление SQL Server 2005 из резервной копии в последнюю позицию файла

Восстановление SQL Server 2005 из резервной копии в последнюю позицию файла

Я пытаюсь восстановить базу данных с диска на последнюю резервную копию. В резервной копии четыре набора резервных копий. Я хотел бы восстановить самую последнюю (сделанную сегодня). Мне нужно сделать это с помощью TSQL.

Этот скрипт ниже работает:

RESTORE DATABASE DatabaseName 
FROM DISK = 'D:\Data\DatabaseName.bak' WITH FILE = 4, REPLACE

Однако в будущем положение файла изменится по мере создания дополнительных резервных копий.

Есть ли способ восстановить резервную копию в позицию файла без указания точного номера файла? Что-то вроде "WITH FILE = most_recent_backup"

решение1

Команда RESTORE HEADERONLYвыдаст вам список данных для всех наборов резервных копий в файле. Оттуда вы можете выбрать максимальное значение Positionи передать его в FILEпараметр.

http://msdn.microsoft.com/en-us/library/ms178536.aspx

решение2

Не помещайте все ваши резервные копии в один файл. Если вы это сделаете и файл будет поврежден, то вы только что потеряли все ваши резервные копии.

Вместо этого при использовании команд BACKUP DATABASE и RESTORE DATABASE помещайте каждую резервную копию в отдельный файл, используя динамическое имя файла.

решение3

Ответ Мэтта направил меня в правильном направлении. Мне нужно было сохранить набор результатов, прежде чем я смогу выбрать максимальную позицию. Мой поиск привел меня к этому решению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 

Связанный контент