当 tempdb 数据文件过大时,可能会需要收缩,下面介绍几种方法以供参考。
如果重启 SQL Server,tempdb 会自动重新创建,tempdb 会回归到初始大小。但是
生产环境是不允许重启 SQL Server服务的
。
下文介绍在线收缩的方法。
使用命令 DBCC SHRINKFILE 收缩单个 tempdb 文件。
DBCC SHRINKFILE命令的详细介绍请参考:DBCC SHRINKFILE (Transact-SQL)
操作步骤:
1.确定主数据文件 (tempdb.mdf)、日志文件 (templog.ldf) 的所需大小,确保在这些文件中使用的空间小于或等于所需的目标大小。
2.用查询分析器连接到 SQL Server,然后为需要收缩的特定数据库运行下列 Transact-SQL 命令:
USE [tempdb]
GO
DBCC SHRINKFILE (N'tempdb.mdf' , 0, TRUNCATEONLY) --释放所有可用空间
GO
DBCC SHRINKFILE (N'tempdb.mdf' , 500) -- 收缩datafile到 500MB
GO
DBCC SHRINKFILE (N'templog.ldf' , 10) -- 收缩日志到 10MB
GO
如果出现无法收缩tempdb的情况,可先使用以下方式处理,再收缩。
USE [tempdb]
GO
DBCC FREESYSTEMCACHE ('ALL') -- PRD环境慎用!!!
GO
DBCC SHRINKFILE (N'tempdb.mdf' , 500)
GO
SQL Server 2005 及后续版本为了增强 tempdb 的性能,会缓存一些 IAM 页,以备将来重新使用这些页面。在这种情况下,必须首先释放 IAM 页,才能释放其对应的页面。因此,通过 DBCC FREESYSTEMCACHE,从所有缓存中释放所有未使用的缓存条目,然后再收缩 tempdb 。