性能调优11:查询统计

查询统计是数据库引起执行请求的统计信息,数据库引擎的工作流程大致归纳为接收请求,执行请求,返回结果。数据库引擎每接收到一个新的查询请求,查询优化器就会生成执行计划,并缓存到内存中;下次再次执行相同的查询请求时,数据库引擎复用已经缓存的执行计划。

数据库引擎会把每一个查询请求的执行信息汇总起来,存储到内存结构 DMV:sys.dm_exec_query_stats中,在该视图中,每一行数据都表示一个查询语句的统计数据:

sql_handle:用以唯一标识一个TSQL文本(Batch或SP),TSQL文本存储在SQL Manager Cache(SQLMGR)中;

plan_handle:用于唯一标识一个已编辑的查询计划,查询计划存储在计划缓存中;

一个sql_handle 能够生成多个查询计划,对应多个plan_handle,但是每个plan_handle只能对应一个sql_handle 。

一,获取查询语句

视图sys.dm_exec_query_stats 缓存的是单个查询语句的执行计划,而sql_handler引用的是整个TSQL文本(Batch或SP),为了获得单个查询语句的文本,必须通过语句的偏移字段来抽取,偏移量是字节,字节数量从0开始:

statement_start_offset:语句开始偏移的字节序号

statement_end_offset:语句结束偏移的字节序号,-1 表示TSQL文本的末尾;

由于函数 sys.dm_exec_sql_text 返回的TSQL文本是以nvarchar(max)类型存储的,一般情况下,字节偏移量都是2的倍数,获取查询语句的脚本是:

select substring(st.text ,qs.statement_start_offset/2+1, ( case when qs.statement_end_offset = -1 then len(convert(nvarchar(max), st.text)) else (qs.statement_end_offset - qs.statement_start_offset)/2 end ) ) as individual_query ,st.text as entire_query from sys.dm_exec_query_stats qs outer apply sys.dm_exec_sql_text(qs.sql_handle) as st

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpdxzx.html