log backup chain被打斷後是不是需要從一個完整備份重新開始?

來源:互聯網
上載者:User

 般我們的理解是logbackup chain被打破後一定需要一個完整備份然後才能開始新的記錄備份,其實不一定需要完整備份,差異備份也是可以的。

 

 

首先我們先做個測試:建立資料庫做完整備份和記錄備份,然後將復原模式變成簡單復原模式。

 

 

CREATEDATABASE LogChainTest;
GO
ALTER DATABASE LogChainTest SET RECOVERY FULL;
GO
BACKUP DATABASE LogChainTest TO DISK = 'D:\MSSQL\LogChainTest.bck' WITH INIT;
GO
BACKUP LOG LogChainTest TO DISK = 'D:\MSSQL\LogChainTest_log1.bck' WITH INIT;
GO
ALTER DATABASE LogChainTest SET RECOVERY SIMPLE;
GO
ALTER DATABASE LogChainTest SET RECOVERY FULL;
GO

 

 

然後再開始一個新的Log備份就會出現下面的錯誤:

 

 

BACKUP LOGLogChainTest TO DISK = 'D:\MSSQL\LogChainTest_log2.bck' WITH INIT;
GO

Msg 4214,Level 16, State 1, Line 1
BACKUP LOG cannot be performed because there is no current database backup.
Msg 3013, Level 16, State 1, Line 1
BACKUP LOG is terminating abnormally.

 

 

我們都知道,資料庫記錄備份包含的是從上次記錄備份以來發生的交易。當我們將資料庫模式更改為簡單以後,SQL Server就會認為這次的記錄備份不會包含所有的日誌交易,所以記錄備份無法完成。

 

 

現在我們做一個差異備份然後再開始做記錄備份就會成功了:

 

 

BACKUPDATABASE LogChainTest TO DISK = 'D:\MSSQL\LogChainTest_Diff1.bck' WITH INIT,DIFFERENTIAL;
GO
BACKUP LOG LogChainTest TO DISK = 'D:\MSSQL\LogChainTest_log2.bck' WITH INIT;
GO

 

 

做完記錄備份之後我做了恢複測試完全沒有問題。

 

 

這個功能針對大資料庫是非常有用的,如果Logbackup chain被打破後,就可以直接選擇差異備份,而不需要執行一次完整備份,這樣可以節省很多時間和資源。

本文出自 “關注SQL Server技術” 部落格,請務必保留此出處http://lzf328.blog.51cto.com/1196996/1032127

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.