当前位置: 代码迷 >> 综合 >> SQL Server TempDB 收缩方法
  详细解决方案

SQL Server TempDB 收缩方法

热度:91   发布时间:2024-01-03 14:23:23.0

当 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 。

  相关解决方案