如何查看SQLSERVER中某个查询用了多少TempDB空间
在SQL Server中,TempDB主要负责供下述三类情况使用:
内部使用(排序、hash join、work table等)
外部使用(临时表,表变量等)
行版本控制(乐观并发控制)
而对于内部使用,一些比较复杂的查询中由于涉及到了大量的并行、排序等操作时就需要大量的内存空间,每一个查询在开始时都会由SQL Server预估需要多少内存,在具体的执行过程中,如果授予的内存不足,则需要将多出来的部分由TempDB处理,这也就是所谓的Spill to TempDB。
通过下述语句可以观察到某个查询对TempDB造成了多少读写:
DECLARE @read BIGINT,
@write BIGINT
;
SELECT @read = SUM(num_of_bytes_read),
@write = SUM(num_of_bytes_written)
FROM tempdb.sys.database_files AS DBF
JOIN sys.dm_io_virtual_file_stats(2, NULL) AS FS
ON FS.file_id = DBF.file_id
WHERE DBF.type_desc = 'ROWS'
--这里放入需要测量的语句
SELECT tempdb_read_MB = (SUM(num_of_bytes_read) - @read) / 1024. / 1024.,
tempdb_write_MB = (SUM(num_of_bytes_written) - @write) / 1024. / 1024.,
internal_use_MB =
(
SELECT internal_objects_alloc_page_count / 128.0
FROM sys.dm_db_task_space_usage
WHERE session_id = @@SPID
)
FROM tempdb.sys.database_files AS DBF
JOIN sys.dm_io_virtual_file_stats(2, NULL) AS FS
ON FS.file_id = DBF.file_id
WHERE DBF.type_desc = 'ROWS'
最近在一个客户那里看到的烂查询所导致的TempDB使用结果如下:

使用该查询就可以帮助了解某个语句使用了多少TempDB。
相关文章
SQLserver2014(ForAlwaysOn)安装图文教程
这篇文章主要介绍了SQLserver2014(ForAlwaysOn)安装图文教程的相关资料,需要的朋友可以参考下2016-04-04
SQLServer"通过端口1433连接到主机localhost的TCP/IP连接失败"常见问题的解
今天碰到一个问题,查了很久,这里给大家总结下,这篇文章主要给大家介绍了关于Java通过JDBC连接SQLServer 2012出现"通过端口1433连接到主机localhost的TCP/IP连接失败"常见问题的解决方案,需要的朋友可以参考下2023-05-05
揭秘SQL Server 2014有哪些新特性(3)-可更新列存储聚集索引
可更新的列存储索引作为SQL Server 2014的一个关键功能之一,在提升数据库的查询性能方面贡献非常突出。据微软统计,在面向OLAP查询统计类系统中,相比其他SQL传统版本的数据库,报表查询的性能最大可提升上十倍。2014-08-08
通过T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填充数据
使用T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填入数据,需要的朋友可以参考下2012-10-10


最新评论