使用GUI还原数据库-还原错误的文件


20

我只是在弄弄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打印:

1个 在此处输入图片说明 哇,哇,等等

该数据库是从另一台服务器(同一服务器,不同实例)还原的。嗯...我想问题出在这里。

你们可以在第二张图片的“服务器”上看到吗?它有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:

是否有重新启动数据库头的内容

(我没主意了)



1
您是否设置了跟踪,然后通过GUI选项运行以捕获SSMS如何获取信息?可能会更快...
Steve Mangiameli '16

1
@RafaelPiccinelli-我觉得一些简单的事情被忽略了,但不确定是什么。您是否将msdb数据库从原始数据库还原到GDLIC2014实例?可能使用了错误的连接字符串或路径吗?当然,SQL Server不会为备份和还原组成数据。(顺便说一句,您正在还原_2.mdf,_3.mdf和_4.mdf,但不是非后缀.mdf或_1.mdf。这很有趣)
RLF

退出使用GUI进行还原。查看备份磁盘或磁带,确定您实际拥有的内容,然后从中开始。
反弱密码

您好@ Anti-weakpasswords。不,不。我不使用GUI。我查询日志序列,然后使用它。我只是对GUI感到好奇,但是后来我看到了这个问题。我尽我所能远离GUI。
Racer SQL

Answers:


1

备份历史记录表中的某些内容可能不同步,并且UI将转到最后一个“一致”的完整备份。如果您真的对它为什么要做什么感兴趣,请启动一个仅限于您的帐户的探查器跟踪,在GUI中完成还原步骤,并查看跟踪中捕获的命令,这些命令显示了UI在后台进行的操作。这将为您提供所需的确切答案。

如果您只想跳过此历史记录,可以通过以下方式清除备份历史记录EXEC [msdb].[dbo].[sp_delete_backuphistory] @oldest_date=getdate()(取决于您上次运行此记录的时间,您可能希望一次清除一个月),然后重新进行一次完整备份,等等。会怀疑这将重置GUI以继续使用正确的备份。

最后,另一个选择是运行Wayne Sheffield编写的脚本。它可能会提供有关备份链任何问题的更多信息。直到我最初发布此答案后,我才遇到这个问题,但是希望它可以在将来对其他人有所帮助。


嘿@john谢谢您的回答。我做了 declare @data datetime set @data=getdate() EXEC msdb.dbo.sp_delete_backuphistory @oldest_date=@data并删除了历史记录。我将进行一些测试,看看是否可行。谢谢。
Racer SQL

嗨@RafaelPiccinelli。它能为您提供帮助吗?
Kefash

嘿@Kefash。我认为这没有用。我现在不记得了。但每次得到答案后,我都会立即投票并选择答案。我认为这不能解决我的问题。
Racer SQL

@john我急需解决此问题。您的问题最终得到解决了吗?
Kefash17年

@RafaelPiccinelli我需要修复此问题,因为当我需要还原到要向HAG添加数据库时可能会很烦。我知道这可以在没有GUI的情况下完成,但是每10分钟记录一次事务日志。您还有哪些其他方法?
Kefash17年
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.