sp_clean_db_free_space (Transact-SQL)

删除因 SQL Server 数据修改例程而留在数据库页上的残留信息。sp_clean_db_free_space 清除数据库中所有文件的所有页。

主题链接图标Transact-SQL 语法约定

语法

sp_clean_db_free_space 
[ @dbname ] = 'database_name' 
[ , [ @cleaning_delay = ] 'delay_in_seconds' ] [;]

参数

  • [ @dbname = ] 'database_name'
    要清理的数据库的名称。dbname 为 sysname 且不能为 NULL。

  • [ @cleaning_delay = ] 'delay_in_seconds'
    指定各次页清理之间的延迟间隔。这会有助于减轻对 I/O 系统的影响。delay_in_seconds 的数据类型为 int,默认值为 0。

返回代码值

0(成功)或 1(失败)

注释

对表的删除操作或更新操作会引发行的移动,通过删除对行的引用可立即释放页上的空间。但是,在某些情况下,该行仍然作为虚影记录而保留在数据页上。后台进程定期清除虚影记录。数据库引擎不会在响应查询时返回该残留数据。但是,在数据或备份文件处于其物理安全性面临风险的环境中时,可以使用 sp_clean_db_free_space 来清除虚影记录。

运行 sp_clean_db_free_space 所需的时间依文件大小、磁盘的可用空间和容量而定。由于运行 sp_clean_db_free_space 对 I/O 活动有较大的影响,我们建议您在常规运行时间之外运行此过程。

鉴于您要运行 sp_clean_db_free_space,我们建议您创建完整数据库备份。

相关的 sp_clean_db_file_free_space 存储过程可清除单个文件。

权限

需要 db_owner 数据库角色中的成员身份。

示例

下面的示例从 AdventureWorks2008R2 数据库中清除所有残留信息。

USE master
GO
EXEC sp_clean_db_free_space 
@dbname = N'AdventureWorks2008R2' ;