当前位置:Gxlcms > 数据库问题 > SQL Server2016 新功能实时查询统计信息

SQL Server2016 新功能实时查询统计信息

时间:2021-07-01 10:21:17 帮助过:2人阅读

使用实时统计查询非常简单,只需要在SSMS的工具列,分别按一下【包括实际的执行计划】【包括实时的统计信息】图标,并执行您的查询就可以了。

技术分享

现在可以在【实时查询统计信息】tab页看到查询所用到的运算符,正在统计查询耗费时间,另外在tab页面的左上角可以看到整个查询的完成度

技术分享

使用【实时查询统计信息】会对性能有一定影响,当查询比较复杂的时候,所需等待时间也会增加,并且整个过程也会耗用不少CPU资源,因此使用的时机必须要审慎,否则问题未查出来,反而造成数据库更大的压力。

 

提示
如果只使用了【包括实时查询统计信息】,而未打开【包括实际执行计划】,那么在【包括实时查询统计信息】的tab页所看到的经过时间和完成率都会是0

不会显示消耗时间

技术分享

 


在执行计划中向下钻取(drill down)

在实时查询统计信息执行过程中,可以点击任何一个执行计划中的运算符,查看运算符的统计信息,例如:消耗时间(Elapsed time)、运算符的处理进度(operator progress)、目前CPU使用率,根据这些信息帮助DBA找出瓶颈所在

技术分享

技术分享


另外,当查询依然在执行时可以切换到活动监视器,在新增加的【活动的耗费大量资源的查询】tab页里能看到当前正在活动的耗时查询,直到该查询执行完毕

技术分享

 

实时查询统计信息原理

实时查询统计信息背后的原理其实是通过DMV动态管理视图获取信息,然后呈现在tab页面上,从而让DBA可以不需要自行查询这些DMV,直接以图形化界面来快速找到长时间执行的查询是在哪个环节耗费最多时间和成本。

 


下面是实时查询统计信息所使用的DMV,当然自己也可以通过下面的DMV来查询获得需要的统计信息

SELECT * FROM  sys.dm_exec_requests
SELECT * FROM sys.dm_exec_sql_text
SELECT * FROM sys.dm_exec_query_memory_grants
SELECT * FROM sys.dm_exec_query_plan
SELECT * FROM sys.dm_exec_query_profiles

 

限制

目前实时查询统计信息尚不支持下列功能

列存储索引(columnstore indexes)
内存优化表(memory optimized tables)
本地编译存储过程(Natively compiled stored procedures)

 

更多SQL Server2016好用功能敬请期待o(∩_∩)o 

SQL Server2016 新功能实时查询统计信息

标签:

人气教程排行