ฉันแค่ล้อเล่นกับอินเทอร์เฟซกราฟิก 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:
ฐานข้อมูลนี้เป็นการกู้คืนจากเซิร์ฟเวอร์อื่น (เซิร์ฟเวอร์เดียวกัน, อินสแตนซ์ต่างกัน) Huuum ... ฉันคิดว่าปัญหาอยู่ที่นี่
พวกคุณเห็นบน "เซิร์ฟเวอร์" ในภาพที่สองได้ไหม? มันมี 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
EDIT5:
มีบางอย่างในการรีสตาร์ทส่วนหัวของฐานข้อมูล
(ฉันหมดความคิด)