slabad
7/3/2014 - 1:09 PM

Generate TLog Restore Script

Generate TLog Restore Script

USE Master; 
GO  
SET NOCOUNT ON 

-- 1 - Variable declaration 
DECLARE @dbName sysname 
DECLARE @backupPath NVARCHAR(500) 
DECLARE @cmd NVARCHAR(500) 
DECLARE @fileList TABLE (backupFile NVARCHAR(255)) 
DECLARE @lastFullBackup NVARCHAR(500) 
DECLARE @lastDiffBackup NVARCHAR(500) 
DECLARE @backupFile NVARCHAR(500) 

-- 2 - Initialize variables 
SET @dbName = 'Thirtyone_Special' 
SET @backupPath = 'G:\mssql\PREPROD_Data1\Backup\Thirtyone_Special_23\LOG\' 

-- 3 - get list of files 
SET @cmd = 'DIR /b ' + @backupPath 

INSERT INTO @fileList(backupFile) 
EXEC master.sys.xp_cmdshell @cmd 

--SELECT * FROM  @fileList

---- 4 - Find latest full backup 
--SELECT @lastFullBackup = MAX(backupFile)  
--FROM @fileList  
--WHERE backupFile LIKE '%.BAK'  
--   AND backupFile LIKE @dbName + '%' 

--SET @cmd = 'RESTORE DATABASE ' + @dbName + ' FROM DISK = '''  
--       + @backupPath + @lastFullBackup + ''' WITH NORECOVERY, REPLACE' 
--PRINT @cmd 

---- 4 - Find latest diff backup 
--SELECT @lastDiffBackup = MAX(backupFile)  
--FROM @fileList  
--WHERE backupFile LIKE '%.DIF'  
--   AND backupFile LIKE @dbName + '%' 
--   AND backupFile > @lastFullBackup 

---- check to make sure there is a diff backup 
--IF @lastDiffBackup IS NOT NULL 
--BEGIN 
--   SET @cmd = 'RESTORE DATABASE ' + @dbName + ' FROM DISK = '''  
--       + @backupPath + @lastDiffBackup + ''' WITH NORECOVERY' 
--   PRINT @cmd 
--   SET @lastFullBackup = @lastDiffBackup 
--END 

-- 5 - check for log backups 
DECLARE backupFiles CURSOR FOR  
   SELECT backupFile  
   FROM @fileList 
   WHERE backupFile LIKE '%.TRN'  
   --AND backupFile LIKE @dbName + '%' 
   --AND backupFile > @lastFullBackup 

OPEN backupFiles  

-- Loop through all the files for the database  
FETCH NEXT FROM backupFiles INTO @backupFile  

WHILE @@FETCH_STATUS = 0  
BEGIN  
   SET @cmd = 'RESTORE LOG ' + @dbName + ' FROM DISK = '''  
       + @backupPath + @backupFile + ''' WITH NORECOVERY' 
   PRINT @cmd 
   FETCH NEXT FROM backupFiles INTO @backupFile  
END 

CLOSE backupFiles  
DEALLOCATE backupFiles  

-- 6 - put database in a useable state 
SET @cmd = 'RESTORE DATABASE ' + @dbName + ' WITH RECOVERY' 
PRINT @cmd