Restauração do SQL Server 2005 do backup para a posição do arquivo mais recente

Restauração do SQL Server 2005 do backup para a posição do arquivo mais recente

Estou tentando restaurar um banco de dados do disco para o backup mais recente. Existem quatro conjuntos de backup no backup. Gostaria de restaurar o mais recente (tirado hoje). Eu preciso ser capaz de fazer isso com TSQL.

Este script abaixo funciona:

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

No entanto, a posição do arquivo mudará no futuro à medida que mais backups forem feitos.

Existe uma maneira de restaurar um backup para uma posição de arquivo sem especificar o número exato do arquivo? Algo como "COM ARQUIVO = most_recent_backup"

Responder1

O RESTORE HEADERONLYcomando fornecerá uma lista de dados de todos os conjuntos de backup no arquivo. A partir daí você pode selecionar o máximo Positione passá-lo para o FILEparâmetro.

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

Responder2

Não coloque todos os seus backups em um único arquivo. Se você fizer isso e o arquivo for corrompido, você perderá todos os seus backups.

Em vez disso, coloque cada backup em seu próprio arquivo usando um nome de arquivo dinâmico ao usar os comandos BACKUP DATABASE e RESTORE DATABASE.

Responder3

A resposta de Matt me colocou na direção certa. Eu precisava armazenar o conjunto de resultados antes de poder selecionar a posição máxima. Minha pesquisa me levou a esta soluçãohttp://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 

informação relacionada