我只是在弄弄SSMS图形界面,并研究“恢复”任务的选项。
我注意到的一件事是,当我单击“生成脚本”时,查询的第一行是:
RESTORE DATABASE [MyDatabase] FROM DISK = N'Server_Patch\Database_name_LOGSHIPPING.BKP' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 5 ( and a lot of log backups for point in time )
好的,没问题,但是,我正在对该数据库进行每日备份。这Database_name_LOGSHIPPING.BKP
是我一个月前用于日志传送的文件的名称。
为什么当我尝试使用SSMS图形界面还原备份时,它指向此备份文件?我什至没有这个文件了。
通过来自MSSQLTIPS的查询,我可以看到该数据库中的所有备份:
SELECT
CONVERT(CHAR(100), SERVERPROPERTY('Servername')) AS Server,
msdb.dbo.backupset.database_name,
msdb.dbo.backupset.backup_start_date,
msdb.dbo.backupset.backup_finish_date,
msdb.dbo.backupset.expiration_date,
CASE msdb..backupset.type
WHEN 'D' THEN 'Database'
WHEN 'L' THEN 'Log'
END AS backup_type,
msdb.dbo.backupset.backup_size,
msdb.dbo.backupmediafamily.logical_device_name,
msdb.dbo.backupmediafamily.physical_device_name,
msdb.dbo.backupset.name AS backupset_name,
msdb.dbo.backupset.description
FROM msdb.dbo.backupmediafamily
INNER JOIN msdb.dbo.backupset ON msdb.dbo.backupmediafamily.media_set_id = msdb.dbo.backupset.media_set_id
WHERE (CONVERT(datetime, msdb.dbo.backupset.backup_start_date, 102) >= GETDATE() - 7) and msdb..backupset.type ='D'
ORDER BY
msdb.dbo.backupset.database_name,
msdb.dbo.backupset.backup_finish_date
这里有什么问题?我不只使用COPY。
编辑2:
我每天都要进行手动备份进行测试,即使这样,SQL Server也会选择不再存在的旧备份。运行RESTORE HEADERONLY...
时说(显然)该文件不存在。
编辑3:
此GUI打印:
该数据库是从另一台服务器(同一服务器,不同实例)还原的。嗯...我想问题出在这里。
你们可以在第二张图片的“服务器”上看到吗?它有2台服务器。我正在将其与名称实例GDLIC2014一起使用。
剧本:
备份脚本:
DECLARE @Patch varchar(1000)
SELECT @Patch = (SELECT 'PATCH\FULL\DATABASE_ ' + convert(varchar(500),GetDate(),112) + '.bkp')
BACKUP DATABASE DATABASE TO DISK=@Patch with compression
使用来自MSSQLTIPS的相同查询,我可以找到这些结果,并且不使用日期范围:
红色方块是较旧实例的错误备份,蓝色方块是上次执行的备份(GUI应使用它)
编辑4:
好了,通过此查询列出了“备份历史记录”,我看到正确列出了每个日志和完整日志:
SELECT TOP 100
s.database_name,
m.physical_device_name,
CAST(CAST(s.backup_size / 1000000 AS INT) AS VARCHAR(14)) + ' ' + 'MB' AS bkSize,
CAST(DATEDIFF(second, s.backup_start_date,
s.backup_finish_date) AS VARCHAR(4)) + ' ' + 'Seconds' TimeTaken,
s.backup_start_date,
CAST(s.first_lsn AS VARCHAR(50)) AS first_lsn,
CAST(s.last_lsn AS VARCHAR(50)) AS last_lsn,
CASE s.[type]
WHEN 'D' THEN 'Full'
WHEN 'I' THEN 'Differential'
WHEN 'L' THEN 'Transaction Log'
END AS BackupType,
s.server_name,
s.recovery_model
FROM msdb.dbo.backupset s
INNER JOIN msdb.dbo.backupmediafamily m ON s.media_set_id = m.media_set_id
WHERE s.database_name = DB_NAME() -- Remove this line for all the database
ORDER BY backup_start_date DESC, backup_finish_date
GO
编辑5:
是否有重新启动数据库头的内容
(我没主意了)