2010-03-30 6 views
7

동일한 .bak 파일을 사용하여 백업을 만듭니다. 이 백업을 자동으로 복원하는 스크립트를 만들었습니다.스크립트를 사용하여 bak 파일에서 최신 백업 복원

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

여기서 복원 할 백업 세트가 명시 적으로 지정됩니다. 그러나 항상 의 최신을 복원하려고합니다. 기본적으로 첫 번째 백업 세트를 사용합니다.

답변

4

결과 세트에 BackupFinishDate가 표시되므로 원하는 특정 백업을 찾으려면 RESTORE HEADERONLY 명령을 사용하십시오. Position이라는 필드를 주목하십시오. FILE 번호입니다.

이 시점에서 논리적 이름을 이미 알고있는 경우 WITH 절의 FILE 옵션을 사용하여 RESTORE 명령을 실행할 수 있습니다.

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

아마도 RESTORE FILELISTONLY 명령을 사용하여 논리 이름을 찾을 수 있습니다.

Tibor Karaszi는 비슷한 해결책을 게시했습니다. http://www.karaszi.com/SQLServer/util_restore_all_in_file.asp 그의 CREATE TABLE 명령을 사용하여 RESTORE HEADERONLY의 결과를 테이블로 가져올 수 있습니다. 내가 아래에 붙여 넣은 것은 테이블에 RESTORE의 결과를 얻는 방법을 보여줍니다 (또한 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

좋은 팁이었습니다. HEADERONLY 옵션을 사용했습니다. Tnx! – Jowen

+1

복원 할 위치에 따라 논리적 파일 이름이 변경됩니까? 또는 논리 파일 이름은 항상 .bak 파일의 모든 백업 세트에서 동일하게됩니까? – Despertar

1

@ Oliver의 이전 답변을 보완하십시오. 다음은 xxx.bak 백업에 대한 HeaderInfo를 표시하는 스크립트 (from here)입니다.

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