如何创建数据库快照 (Transact-SQL)

任何能创建数据库的用户都可以创建数据库快照。创建快照的唯一方式是使用 Transact-SQL。

ms175876.note(zh-cn,SQL.90).gif注意:
有关命名数据库快照、设置创建数据库快照的时间和限制数据库快照成员的注意事项,请参阅创建数据库快照

创建数据库快照

  1. 根据源数据库的当前大小,确保有足够的磁盘空间存放数据库快照。数据库快照的最大大小为创建快照时源数据库的大小。

  2. 使用 AS SNAPSHOT OF 子句对文件执行 CREATE DATABASE 语句。创建快照需要指定源数据库的每个数据库文件的逻辑名称。有关创建数据库快照的语法的正式说明,请参阅 CREATE DATABASE (Transact-SQL)

    ms175876.note(zh-cn,SQL.90).gif注意:
    创建数据库快照时,CREATE DATABASE 语句中不允许有日志文件、离线文件、还原文件和不起作用的文件。

示例

本节包含创建数据库快照的示例。

A. 对 AdventureWorks 数据库创建快照

此示例对 AdventureWorks 数据库创建数据库快照。快照名称 AdventureWorks_dbss_1800 及其稀疏文件的名称 AdventureWorks_data_1800.ss 指明了创建时间 6 P.M.(1800 小时)。

CREATE DATABASE AdventureWorks_dbss1800 ON
( NAME = AdventureWorks_Data, FILENAME = 
'C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\Data\AdventureWorks_data_1800.ss' )
AS SNAPSHOT OF AdventureWorks;
GO
ms175876.note(zh-cn,SQL.90).gif注意:
示例中随意使用了扩展名 .ss。
B. 对 Sales 数据库创建快照

此示例对 Sales 数据库创建数据库快照 sales_snapshot1200。此数据库是在 CREATE DATABASE (Transact-SQL) 中的“创建具有文件组的数据库”示例中创建的。

--Creating sales_snapshot1200 as snapshot of the
--Sales database:
CREATE DATABASE sales_snapshot1200 ON
( NAME = SPri1_dat, FILENAME = 
'C:\Program Files\Microsoft SQL Server\mssql.1\mssql\data\SPri1dat_1200.ss'),
( NAME = SPri2_dat, FILENAME = 
'C:\Program Files\Microsoft SQL Server\mssql.1\mssql\data\SPri2dt_1200.ss'),
( NAME = SGrp1Fi1_dat, FILENAME = 
'C:\Program Files\Microsoft SQL Server\mssql.1\mssql\data\SG1Fi1dt_1200.ss'),
( NAME = SGrp1Fi2_dat, FILENAME = 
'C:\Program Files\Microsoft SQL Server\mssql.1\mssql\data\SG1Fi2dt_1200.ss'),
( NAME = SGrp2Fi1_dat, FILENAME = 
'C:\Program Files\Microsoft SQL Server\mssql.1\mssql\data\SG2Fi1dt_1200.ss'),
( NAME = SGrp2Fi2_dat, FILENAME = 
'C:\Program Files\Microsoft SQL Server\mssql.1\mssql\data\SG2Fi2dt_1200.ss')
AS SNAPSHOT OF Sales
GO

请参阅

任务

如何查看数据库快照 (SQL Server Management Studio)
如何将数据库恢复到数据库快照 (Transact-SQL)
如何删除数据库快照 (Transact-SQL)

其他资源

CREATE DATABASE (Transact-SQL)
SQL Server Management Studio 教程

帮助和信息

获取 SQL Server 2005 帮助