数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间
这篇文章主要为大家展示了“数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间”这篇文章吧。
在SQL Server中,TempDB主要负责供下述三类情况使用:
内部使用(排序、hash join、work table等)外部使用(临时表,表变量等)行版本控制(乐观并发控制) 而对于内部使用,一些比较复杂的查询中由于涉及到了大量的并行、排序等操作时就需要大量的内存空间,每一个查询在开始时都会由SQL Server预估需要多少内存,在具体的执行过程中,如果授予的内存不足,则需要将多出来的部分由TempDB处理,这也就是所谓的Spill to TempDB。
通过下述语句可以观察到某个查询对TempDB造成了多少读写:
DECLARE@readBIGINT,@writeBIGINT;SELECT@read=SUM(num_of_bytes_read),@write=SUM(num_of_bytes_written)FROMtempdb.sys.database_filesASDBFJOINsys.dm_io_virtual_file_stats(2,NULL)ASFSONFS.file_id=DBF.file_idWHEREDBF.type_desc='ROWS'--这里放入需要测量的语句SELECTtempdb_read_MB=(SUM(num_of_bytes_read)-@read)/1024./1024.,tempdb_write_MB=(SUM(num_of_bytes_written)-@write)/1024./1024.,internal_use_MB=(SELECTinternal_objects_alloc_page_count/128.0FROMsys.dm_db_task_space_usageWHEREsession_id=@@SPID)FROMtempdb.sys.database_filesASDBFJOINsys.dm_io_virtual_file_stats(2,NULL)ASFSONFS.file_id=DBF.file_idWHEREDBF.type_desc='ROWS'
以上是“数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。