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 만 사용하고 있습니다.
EDIT2 :
테스트를 위해 매일 수동 백업을 만들고 있는데,이 방법으로도 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 :
데이터베이스 헤더를 다시 시작할 무언가가 있습니까?
(나는 아이디어가 없다)