备份文件和文件组 (SQL Server)
本主题说明如何使用 SQL Server Management Studio、Transact-SQL 或 PowerShell 在 SQL Server 2012 中备份文件和文件组。 当数据库大小和性能要求使完整数据库备份显得不切实际,则可以创建文件备份。 “文件备份”包含一个或多个文件(或文件组)中的所有数据。 有关文件备份的详细信息,请参阅完整文件备份 (SQL Server)和差异备份 (SQL Server)。
本主题内容
开始之前:
限制和局限
建议
安全性
若要备份文件和文件组,可使用:
SQL Server Management Studio
Transact-SQL
PowerShell
开始之前
限制和局限
不允许在显式或隐式事务中使用 BACKUP 语句。
在简单恢复模式下,必须一起备份所有读/写文件。 这有助于确保将数据库还原到一致的时点。 请使用 READ_WRITE_FILEGROUPS 选项,而不是逐个指定每个读/写文件或文件组。 此选项用于备份数据库中的所有读/写文件组。 通过指定 READ_WRITE_FILEGROUPS 创建的备份称为“部分备份”。 有关详细信息,请参阅部分备份 (SQL Server)。
有关限制的详细信息,请参阅备份概述 (SQL Server)。
建议
- 默认情况下,每个成功的备份操作都会在 SQL Server 错误日志和系统事件日志中添加一个条目。 如果非常频繁地备份日志,这些成功消息会迅速累积,从而产生一个巨大的错误日志,这样会使查找其他消息变得非常困难。 在这些情况下,如果任何脚本均不依赖于这些日志条目,则可以使用跟踪标志 3226 取消这些条目。 有关详细信息,请参阅跟踪标志 (Transact-SQL)。
安全性
权限
默认情况下,为 sysadmin 固定服务器角色以及 db_owner 和 db_backupoperator 固定数据库角色的成员授予 BACKUP DATABASE 和 BACKUP LOG 权限。
备份设备的物理文件的所有权和权限问题可能会妨碍备份操作。 SQL Server 必须能够读取和写入设备;运行 SQL Server 服务的帐户必须具有写入权限。 但是,用于在系统表中为备份设备添加项目的 sp_addumpdevice 不检查文件访问权限。 备份设备物理文件的这些问题可能直到为备份或还原而访问物理资源时才会出现。
[返回页首]
使用 SQL Server Management Studio
备份数据库文件和文件组
连接到相应的 SQL Server 数据库引擎实例之后,在对象资源管理器中,单击服务器名称以展开服务器树。
展开**“数据库”,然后根据数据库的不同,选择用户数据库,或展开“系统数据库”**,再选择系统数据库。
右键单击数据库,指向**“任务”,再单击“备份”。 将出现“备份数据库”**对话框。
在**“数据库”**列表中,验证数据库名称。 您也可以从列表中选择其他数据库。
在**“备份类型”列表中,选择“完整”或“差异”**。
对于**“备份组件”选项,单击“文件和文件组”**。
在**“选择文件和文件组”**对话框中,选择要备份的文件和文件组。 可以选择一个或多个单个文件,也可以复选文件组的框,从而自动选择该文件组中的所有文件。
可以接受**“名称”**文本框中建议的默认备份集名称,也可以为备份集输入其他名称。
或者,在**“说明”**文本框中,输入备份集的说明。
指定备份集的过期时间:
若要让备份集在特定天数之后过期,请单击**“之后”**(默认选项)。 然后,输入备份集自创建后到过期日之间的天数。 此值范围为 0 到 99999 天;0 天表示备份集将永不过期。
默认值在**“服务器属性”对话框(位于“数据库设置”页上)的“默认备份介质保持期(天)”选项中设置。 若要访问此选项,请在对象资源管理器中右键单击服务器名称,并选择“属性”,然后选择“数据库设置”**页。
若要使备份集在特定日期过期,请单击**“在”**,并输入备份集的过期日期。
通过单击**“磁盘”或“磁带”,选择备份目标的类型。 若要选择包含单个介质集的多个磁盘驱动器或磁带机(最多为 64 个)的路径,请单击“添加”。 所选路径将显示在“备份到”**列表中。
注意 若要删除备份目标,请选择该备份目标并单击“删除”。 若要查看备份目标的内容,请选择该备份目标并单击“内容”。
若要查看或选择高级选项,请在**“选择页”窗格中单击“选项”**。
可以通过单击以下选项之一来选择**“覆盖介质”**选项:
备份到现有介质集
对于此选项,请单击**“追加到现有备份集”或“覆盖所有现有备份集”**。 有关备份到现有介质集的信息,请参阅介质集、介质簇和备份集 (SQL Server)。
或者选择**“检查介质集名称和备份集过期时间”**,以使备份操作对介质集和备份集的过期日期和时间进行验证。
或者在**“介质集名称”**文本框中输入名称。 如果没有指定名称,将使用空白名称创建介质集。 如果指定了介质集名称,将检查介质(磁带或磁盘),以确定实际名称是否与此处输入的名称匹配。
如果将介质名称保留空白,并选中该框以便与介质进行核对,则只有当介质上的介质名称也是空白时才能成功。
备份到新介质集并清除所有现有备份集
对于该选项,请在**“新建介质集名称”文本框中输入名称,并在“新建介质集说明”**文本框中描述介质集(可选)。 有关创建新介质集的详细信息,请参阅介质集、介质簇和备份集 (SQL Server)。
在**“可靠性”**部分中,根据需要选中以下任意选项:
完成后验证备份。
“写入介质前检查校验和”和“出现校验和错误时继续”(可选)。 有关校验和的详细信息,请参阅在备份和还原期间可能的介质错误 (SQL Server)。
如果备份到磁带机(如同**“常规”页的“目标”部分指定的一样),则“备份后卸载磁带”选项处于活动状态。 单击此选项可以启用“卸载前倒带”**选项。
注意 除非备份的是事务日志(如同“常规”页的“备份类型”部分中指定的一样),否则“事务日志”部分中的选项处于不活动状态。
SQL Server 2008 Enterprise 及更高版本支持备份压缩。 默认情况下,是否压缩备份取决于 backup-compression default 服务器配置选项的值。 但是,不管当前服务器级默认设置如何,您都可以通过选中**“压缩备份”来压缩备份,并且可以通过选中“不压缩备份”**来防止压缩备份。
查看当前备份压缩默认值
[返回页首]
使用 Transact-SQL
备份文件和文件组
若要创建文件或文件组备份,请使用 BACKUP DATABASE <file_or_filegroup> 语句。 此语句至少必须指定以下各项:
数据库名称。
FILE 或 FILEGROUP 子句(为每个文件或文件组分别指定)。
将写入完整备份的备份设备。
用于文件备份的基本 Transact-SQL 语法如下:
BACKUP DATABASE database
{ FILE = logical_file_name | FILEGROUP = logical_filegroup_name } [ ,...f]
TO backup_device [ ,...n]
[ WITH with_options [ ,...o] ] ;
选项
说明
database
备份事务日志、部分数据库或完整的数据库时所用的源数据库。
FILE = logical_file_name
指定要包含在文件备份中的文件的逻辑名称。
FILEGROUP = logical_filegroup_name
指定要包含在文件备份中的文件组的逻辑名称。 在简单恢复模式下,只允许对只读文件组执行文件组备份。
[ ,...f]
表示可以指定多个文件和文件组的占位符。 不限制文件或文件组的数量。
backup_device [ ,...n]
指定一个列表,它包含 1 至 64 个用于备份操作的备份设备。 您可以指定物理备份设备,也可以指定对应的逻辑备份设备(如果已定义)。 若要指定物理备份设备,请使用 DISK 或 TAPE 选项:
{ DISK | TAPE } = physical_backup_device_name
有关详细信息,请参阅备份设备 (SQL Server)。
WITH with_options [ ,...o]
您也可以指定一个或多个附加选项,如 DIFFERENTIAL。
注意 差异文件备份需要以完整文件备份为基础。 有关详细信息,请参阅创建差异数据库备份 (SQL Server)。
在完整恢复模式下,还必须备份事务日志。 若要使用一整套文件的完整备份来还原数据库,您还必须拥有足够的日志备份,以便涵盖从第一个文件备份开始的所有文件备份。 有关详细信息,请参阅备份事务日志 (SQL Server)。
示例 (Transact-SQL)
下面的示例备份了 Sales 数据库的辅助文件组的一个或多个文件。 此数据库使用完整恢复模式并且包含以下辅助文件组:
名为 SalesGroup1 的文件组,它包含文件 SGrp1Fi1 和 SGrp1Fi2。
名为 SalesGroup2 的文件组,它包含文件 SGrp2Fi1 和 SGrp2Fi2。
A.为两个文件创建文件备份
下面的示例仅为 SalesGroup1 文件组的 SGrp1Fi2 文件和 SalesGroup2 文件组的 SGrp2Fi2 文件创建差异文件备份。
--Backup the files in the SalesGroup1 secondary filegroup.
BACKUP DATABASE Sales
FILE = 'SGrp1Fi2',
FILE = 'SGrp2Fi2'
TO DISK = 'G:\SQL Server Backups\Sales\SalesGroup1.bck';
GO
B.创建辅助文件组的完整文件备份
下面的示例为两个辅助文件组中的所有文件创建完整文件备份。
--Back up the files in SalesGroup1.
BACKUP DATABASE Sales
FILEGROUP = 'SalesGroup1',
FILEGROUP = 'SalesGroup2'
TO DISK = 'C:\MySQLServer\Backups\Sales\SalesFiles.bck';
GO
C.创建辅助文件组的差异文件备份
下面的示例将对两个辅助文件组中的各个文件创建差异文件备份。
--Back up the files in SalesGroup1.
BACKUP DATABASE Sales
FILEGROUP = 'SalesGroup1',
FILEGROUP = 'SalesGroup2'
TO DISK = 'C:\MySQLServer\Backups\Sales\SalesFiles.bck'
WITH
DIFFERENTIAL;
GO
[返回页首]
使用 PowerShell
使用 Backup-SqlDatabase cmdlet 并且为 -BackupAction 参数的值指定 Files。 此外,还指定下列参数之一:
若要备份某个特定的文件,请指定 -DatabaseFile String 参数,其中,String 是要备份的一个或多个数据库文件。
若要备份某个给定文件组中的所有文件,请指定 -DatabaseFileGroup String 参数,其中,String 是要备份的一个或多个数据库文件组。
下面的示例在 MyDB 数据库中创建辅助文件组“FileGroup1”和“FileGroup2”中的每个文件的完整文件备份。 将在服务器实例 Computer\Instance 的默认备份位置上创建备份。
--Enter this command at the PowerShell command prompt, C:\PS> Backup-SqlDatabase -ServerInstance Computer\Instance -Database MyDB -BackupAction Files -DatabaseFileGroup "FileGroup1","FileGroup2"
设置和使用 SQL Server PowerShell 提供程序
[返回页首]