sql server 2008 壓縮備份數(shù)據(jù)庫(kù)(20g)
今天需要把一個(gè)省外項(xiàng)目的數(shù)據(jù)庫(kù)從服務(wù)器上備份、拷貝到本機(jī)(跨地域傳輸數(shù)據(jù)庫(kù)備份文件)。
連上VPN,通過(guò)遠(yuǎn)程桌面連接,連接上服務(wù)器,發(fā)現(xiàn)數(shù)據(jù)庫(kù)文件已經(jīng)有20G以上大小了。
文件太大,公司網(wǎng)絡(luò)也不穩(wěn)定,根本不可能通過(guò)網(wǎng)絡(luò)傳輸過(guò)來(lái)。
于是,把數(shù)據(jù)庫(kù)的恢復(fù)模式由“完整”模式設(shè)置為“簡(jiǎn)單”模式,接著收縮數(shù)據(jù)庫(kù),
數(shù)據(jù)庫(kù)瞬間由20G變成1G多點(diǎn)。
在SSMS中,新建查詢窗口,執(zhí)行數(shù)據(jù)庫(kù)備份語(yǔ)句:
--定義變量,把備份數(shù)據(jù)庫(kù)的QL腳本賦值給變量 declare @SqlBackupDataBase as nvarchar(1000) set @SqlBackupDataBase=N'BACKUP DATABASE Northwind TO DISK = ''D:\Northwind-'+ CONVERT(varchar(11),GETDATE(),112)+REPLACE(CONVERT(varchar(12),GETDATE(),108),':','')+'.bak''' --備份文件格式:Northwind-20170111132424.bak exec sp_executesql @SqlBackupDataBase --調(diào)用系統(tǒng)存儲(chǔ)過(guò)程,執(zhí)行SQL
備份成功后,備份的bak文件有1.16G大?。?/p>
接著,興沖沖地拷貝bak文件到本機(jī),
結(jié)果:總是在傳輸?shù)倪^(guò)程中,傳輸自動(dòng)中斷。
原因是 網(wǎng)絡(luò)不穩(wěn)定,網(wǎng)絡(luò)的帶寬限制。
想想,能不能備份成更小的bak文件呢?
最后用到了sql server 2008 以上版本的數(shù)據(jù)庫(kù)的新特性:壓縮備份數(shù)據(jù)庫(kù)。
其實(shí)就是在備份數(shù)據(jù)庫(kù)的語(yǔ)句上加上 “with STATS = 1,compression”,
完整壓縮備份數(shù)據(jù)庫(kù)語(yǔ)句如下:
--定義變量,把備份數(shù)據(jù)庫(kù)的QL腳本賦值給變量 declare @SqlBackupDataBase as nvarchar(1000) set @SqlBackupDataBase=N'BACKUP DATABASE Northwind TO DISK = ''D:\Northwind-'+ CONVERT(varchar(11),GETDATE(),112)+REPLACE(CONVERT(varchar(12),GETDATE(),108),':','')+'.bak''' +'with STATS = 1,compression' --備份文件格式:Northwind-20170111132424.bak exec sp_executesql @SqlBackupDataBase --調(diào)用系統(tǒng)存儲(chǔ)過(guò)程,執(zhí)行SQL
備份成功后,發(fā)現(xiàn)備份的bak文件只有160MB大?。?/p>
最后順利地把這個(gè)數(shù)據(jù)庫(kù)備份文件拷貝并還原到本機(jī)數(shù)據(jù)庫(kù)。
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。