数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间

发布时间:2021-11-09 10:33:23 作者:小新
来源:亿速云 阅读:281

这篇文章主要为大家展示了“数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“数据库中怎么查看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 DBFJOIN  sys.dm_io_virtual_file_stats(2, NULL) AS FS    ON FS.file_id = DBF.file_idWHERE  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 DBFJOIN  sys.dm_io_virtual_file_stats(2, NULL) AS FS    ON FS.file_id = DBF.file_idWHERE  DBF.type_desc = 'ROWS'

以上是“数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. 数据库中如何查看哪个SP调用了对应的表
  2. SQLServer中Tempdb空间异常增长及占用非常大该怎么办

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

数据库 sql server

上一篇:如何解决安装oracle软件出现PRVF-4354问题

下一篇:如何解析Linux /etc/shadow

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》