度量快速开发平台-专业、快速的软件定制快开平台

标题: 查询统计 [打印本页]

作者: Adam丶鱼    时间: 2020-6-4 20:37
标题: 查询统计
[size=13.3333px]数据库引擎接收到一个新的查询请求(Batch或SP),查询优化器会生成执行计划,并缓存到内存中;下次再次执行相同的查询请求时,数据库引擎从复用已经缓存的执行计划,换句话,数据库引擎为每一个查询请求生成执行计划,并把已经生成的执行计划缓存起来,当接收到相同的查询请求时,数据库引擎复用已缓存的执行计划。查询请求(Batch或SP)中的每一个查询语句的执行计划,都会被缓存到内存中,数据库引擎统计执行计划的性能参数,缓存在DMV:sys.dm_exec_query_stats中,在该视图中,每一行数据都表示一个查询语句的统计数据:
[size=13.3333px]一个sql_handle 能够生成多个查询计划,对应多个plan_handle,但是每个plan_handle只能对应一个sql_handle
[size=13.3333px]一,获取查询语句
[size=13.3333px]视图sys.dm_exec_query_stats 缓存的是单个查询语句的执行计划,而sql_handler引用的是整个TSQL文本(Batch或SP),为了获得单个查询语句的文本,必须通过语句的偏移字段来抽取,偏移量是字节,字节数量从0开始:
[size=13.3333px]由于函数 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


作者: Adam丶鱼    时间: 2020-6-4 20:38

作者: fteair    时间: 2020-6-5 14:28

作者: Adam丶鱼    时间: 2020-6-6 17:56
fteair 发表于 2017-7-5 14:28


作者: fteair    时间: 2020-6-7 13:55
Adam丶鱼 发表于 2017-7-6 17:56






欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://p.delit.cn/) Powered by Discuz! X3.2