Восстановить последнюю резервную копию из файла bak с помощью скрипта

Я создаю резервные копии, используя тот же .файл бак. Я сделал сценарий для автоматического восстановления этой резервной копии.

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

здесь явно указан резервный набор для восстановления. Тем не менее, я всегда хочу восстановить последний набор в наличии. По умолчанию используется первый резервный набор.

2 ответов


используйте команду RESTORE HEADERONLY, чтобы найти нужную резервную копию, так как этот результирующий набор показывает BackupFinishDate. Обратите внимание на поле с именем Position; это номер файла.

на этом этапе, если вы уже знаете логические имена, вы можете запустить команду RESTORE, используя опцию FILE в предложении WITH.

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

вы, вероятно, уже знаете, что вы можете использовать команду RESTORE FILELISTONLY для поиска логических имен.

Тибор Карасци имеет опубликовано аналогичное (но не то же самое) решение здесь:http://www.karaszi.com/SQLServer/util_restore_all_in_file.asp вы можете использовать его команды CREATE TABLE, чтобы получить результаты восстановления HEADERONLY в таблицу. То, что я вставил ниже, показывает, как получить результаты восстановления FILELISTONLY в таблицу (также разорванную из Тибора).

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
;

чтобы увеличить предыдущий ответ @ Oliver. Вот сценарий (отсюда), чтобы показать HeaderInfo для вашего xxx.бак.

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