SQL Server TempDB 收缩方法

30 篇文章 4 订阅
22 篇文章 1 订阅

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值