2010-03-30 21 views
7

Tworzę kopie zapasowe za pomocą tego samego pliku .bak. Zrobiłem skrypt, aby automagicznie przywrócić tę kopię zapasową.Przywróć najnowszą kopię zapasową z pliku bak za pomocą skryptu

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

W tym miejscu zestaw kopii zapasowych do przywracania jest jawnie określony. Jednak zawsze chcę przywrócić dostępny najnowszy dostępny zestaw . Domyślnie używa pierwszego zestawu kopii zapasowych.

Odpowiedz

4

Użyj polecenia RESTORE HEADERONLY, aby zlokalizować określoną kopię zapasową, ponieważ ten zestaw wyników pokazuje BackupFinishDate. Zwróć uwagę na pole o nazwie Pozycja; to jest numer PLIKU.

W tym momencie, jeśli znasz już nazwy logiczne, możesz uruchomić polecenie RESTORE, używając opcji PLIK w klauzuli WITH.

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

Prawdopodobnie już wiesz, że możesz użyć polecenia RESTORE FILELISTONLY, aby znaleźć nazwy logiczne.

Tibor Karaszi opublikował podobne (ale nie to samo) rozwiązanie tutaj: http://www.karaszi.com/SQLServer/util_restore_all_in_file.asp Możesz użyć jego poleceń CREATE TABLE, aby uzyskać wyniki PRZYWRÓĆ HEADERONLY do tabeli. To, co wkleiłem poniżej pokazuje, jak uzyskać wyniki PRZYWRÓĆ FILELISTNIE DO stołu (również zgrane z Tibora).

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

To była dobra wskazówka, skorzystałem z opcji HEADERONLY. Tnx! – Jowen

+1

Czy nazwa pliku logicznego zmieni się w zależności od tego, która pozycja zostanie przywrócona? Czy logiczna nazwa pliku zawsze będzie taka sama dla wszystkich zestawów kopii zapasowych w pliku .bak? – Despertar

1

Aby powiększyć poprzednią odpowiedź Olivera. Oto skrypt (from here), aby wyświetlić plik HeaderInfo dotyczący kopii zapasowej pliku 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 
Powiązane problemy