数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间-创新互联

这篇文章主要为大家展示了“数据库中怎么查看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空间”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


分享文章:数据库中怎么查看SQLSERVER中某个查询用了多少TempDB空间-创新互联
新闻来源:http://azwzsj.com/article/dieieg.html