SQLSERVER数据备份文件的分割备份方法

2022-05-23 0 580

当完整备份数据库的时候,我们有时候可能会遇到一种极端情况,比如服务器上C,D,E三个盘符都只剩下5G空间了

但是如果要完整备份业务库需要12G的空间,那么这时候怎么办呢?

使用文件组备份吗?但是数据库没有做表分区,没有分多个文件组,就只有一个主文件组啊

这时候我们可以使用备份文件分割

我使用自己机器示范一下,我的机器上有一个Temp2的数据库,数据库大小为1GB

SQLSERVER数据备份文件的分割备份方法

备份

我们做一个Temp2数据库的完整备份

复制代码 代码如下:

DECLARE @CurrentTime VARCHAR(50), @FileName VARCHAR(200)SET @CurrentTime = REPLACE(REPLACE(REPLACE(CONVERT(VARCHAR, GETDATE(), 120 ),’-‘,’_’),’ ‘,’_’),’:’,”)        –(Temp2 数据库完整备份)SET @FileName = ‘C:\Temp2_FullBackup_’ + @CurrentTime+’.bak’BACKUP DATABASE [Temp2]TO DISK=@FileName WITH FORMAT

可以看到需要31MB大小

SQLSERVER数据备份文件的分割备份方法

那么如何分割备份文件呢?方法很简单

刚才是备份到C盘,现在我们备份到C盘和D盘

复制代码 代码如下:

DECLARE @CurrentTime VARCHAR(50), @FileName VARCHAR(200),@FileName2 VARCHAR(200)SET @CurrentTime = REPLACE(REPLACE(REPLACE(CONVERT(VARCHAR, GETDATE(), 120 ),’-‘,’_’),’ ‘,’_’),’:’,”)        –(Temp2 数据库完整备份)SET @FileName = ‘C:\Temp2_FullBackup_Partial1_’ + @CurrentTime+’.bak’SET @FileName2 = ‘D:\Temp2_FullBackup_Partial2_’ + @CurrentTime+’.bak’BACKUP DATABASE [Temp2]TO DISK=@FileName,DISK=@FileName2WITH FORMAT

C盘

SQLSERVER数据备份文件的分割备份方法

SQLSERVER数据备份文件的分割备份方法

D盘

SQLSERVER数据备份文件的分割备份方法

SQLSERVER数据备份文件的分割备份方法

可以看到每个备份文件的大小是平均的,都是16MB,如果是分成3个备份文件,那么就除以3,就是每个备份文件的大小

当然,如果你要查询备份文件的信息,无论查询哪个备份文件都是可以查询出来的

复制代码 代码如下:

RESTORE FileListOnly From Disk=’C:\Temp2_FullBackup_Partial1_2014_12_19_150533.bak’RESTORE FileListOnly From Disk=’D:\Temp2_FullBackup_Partial2_2014_12_19_150533.bak’RESTORE HeaderOnly From Disk=’C:\Temp2_FullBackup_Partial1_2014_12_19_150533.bak’RESTORE HeaderOnly From Disk=’D:\Temp2_FullBackup_Partial2_2014_12_19_150533.bak’

SQLSERVER数据备份文件的分割备份方法

还原

复制代码 代码如下:

USE [master]RESTORE DATABASE [Temp2] FROM  DISK = N’D:\Temp2_FullBackup_Partial1_2014_12_19_150533.bak’,DISK = N’D:\Temp2_FullBackup_Partial2_2014_12_19_150533.bak’ WITH  FILE = 1,  MOVE N’Temp’ TO N’E:\DataBase\Temp2.mdf’,  MOVE N’Temp_log’ TO N’E:\DataBase\Temp2_log.ldf’,  NOUNLOAD,  REPLACE,  STATS = 5

GO

还原的时候只需要指定所有的备份分割文件的路径就可以了,当然我们一般在服务器搬迁的时候都会把这些备份文件一起放到新服务器的同一个盘符下面,方便还原

而不会一个放C盘,一个放D盘,一个放E盘

SQLSERVER数据备份文件的分割备份方法

还原好了,我们查询一下数据

SQLSERVER数据备份文件的分割备份方法

SQLSERVER数据备份文件的分割备份方法

还原出来的数据库没有问题,可以收工了

总结

有时候当服务器的任何一个盘符的空间都不足以放下一个完整备份文件,但是又急需要做一个完整备份,那么可以采取这种办法

当然,你也可以插入一个移动硬盘,将数据库备份到一个移动硬盘里去,但是当你做集群搬迁,只能远程到服务器去做备份的时候,这种办法就比较有用了

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 MsSql SQLSERVER数据备份文件的分割备份方法 https://www.niceym.com/55452.html