2010-03-30 11 views
7

Creo copias de seguridad usando el mismo archivo .bak. Hice una secuencia de comandos para restaurar automágicamente esta copia de seguridad.Restaurar la última copia de seguridad del archivo bak con la secuencia de comandos

RESTORE DATABASE [xxx] FROM DISK = N'xxx.bak' 
WITH FILE = 10, NOUNLOAD, REPLACE, STATS = 10 
GO 

Aquí, el conjunto de copia de seguridad para restaurar está explícitamente especificado. Sin embargo, siempre quiero restaurar el último conjunto disponible. Por defecto, usa el primer conjunto de respaldo.

Respuesta

4

Utilice el comando RESTORE HEADERONLY para localizar la copia de seguridad particular que desee, ya que el conjunto de resultados muestra la fecha de finalización de la copia de seguridad. Tenga en cuenta el campo denominado Posición; ese es el número de ARCHIVO.

En este punto, si ya conoce los nombres lógicos, puede ejecutar un comando RESTORE utilizando la opción FILE en la cláusula WITH.

restore database yourDB 
from disk = N'C:\Program Files\Microsoft SQL Server\yourDB.bak' 
with 
    file = 3 

Probablemente ya sepa que puede usar el comando RESTORE FILELISTONLY para buscar los nombres lógicos.

Tibor Karaszi ha publicado una solución similar (pero no igual) aquí: http://www.karaszi.com/SQLServer/util_restore_all_in_file.asp Puede usar sus comandos CREATE TABLE para obtener los resultados de RESTORE HEADERONLY en una tabla. Lo que he pegado a continuación muestra cómo obtener RESTORE FILELISTONLY en una tabla (también arrancada de Tibor).

create table FLO_results (
    LogicalName nvarchar(128), 
    PhysicalName nvarchar(260), 
    [Type] char(1), 
    FileGroupName nvarchar(128), 
    Size numeric(20,0), 
    MaxSize numeric(20,0), 
    FileId bigint, 
    CreateLSN numeric(25,0), 
    DropLSN numeric(25,0), 
    UniqueId uniqueidentifier, 
    ReadOnlyLSN numeric(25,0), 
    ReadWriteLSN numeric(25,0), 
    BackupSizeInBytes bigint, 
    SourceBlockSize bigint, 
    FilegroupId bigint, 
    LogGroupGUID uniqueidentifier, 
    DifferentialBaseLSN numeric(25), 
    DifferentialBaseGUID uniqueidentifier, 
    IsReadOnly int, 
    IsPresent int 
) 
; 
insert into FLO_results 
exec(' 
    restore filelistonly from disk = ''C:\Program Files\Microsoft SQL Server\yourDB.bak'' 
') 
; 
select * from FLO_results 
; 
drop table FLO_results 
; 
+0

Eso fue un buen consejo, utilicé la opción HEADERONLY. Tnx! – Jowen

+1

¿Cambiará el nombre del archivo lógico dependiendo de qué posición se restaura? ¿O el nombre de archivo lógico siempre será el mismo para todos los conjuntos de copia de seguridad en un archivo .bak? – Despertar

1

Para aumentar la respuesta anterior de Oliver. Aquí está el script (from here) para mostrar HeaderInfo para su copia de seguridad xxx.bak.

DECLARE @HeaderInfo table 
     (
      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, 
      CompressedBackupSize numeric(20,0) 
    ) 


INSERT INTO @HeaderInfo EXEC('RESTORE HEADERONLY 
FROM DISK = N''xxx.bak'' 
WITH NOUNLOAD') 

SELECT * FROM @HeaderInfo 
Cuestiones relacionadas