sql server性能分析--DMV之(sys.dm_exec_query_stats )
2010-05-06 09:42
573 查看
在做查询优化时,有时总找不到相应的要优化的东东;在做查询分析时看了半天代码不,写得太规范,又没注释;
只能想别的方法解决这一问题;
先清除缓存:
dbcc freeProcCache
找出哪些SQL跟数据库还有表对象
SELECT DB_ID(DB.dbid) '数据库名'
, OBJECT_ID(db.objectid) '对象'
, QS.creation_time '编译计划的时间'
, QS.last_execution_time '上次执行计划的时间'
, QS.execution_count '执行的次数'
, QS.total_elapsed_time / 1000 '占用的总时间(秒)'
, QS.total_physical_reads '物理读取总次数'
, QS.total_worker_time / 1000 'CPU 时间总量(秒)'
, QS.total_logical_writes '逻辑写入总次数'
, QS.total_logical_reads N'逻辑读取总次数'
, QS.total_elapsed_time / 1000 N'总花费时间(秒)'
, SUBSTRING(ST.text, ( QS.statement_start_offset / 2 ) + 1,
( ( CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE QS.statement_end_offset
END - QS.statement_start_offset ) / 2 ) + 1) AS '执行语句'
FROM sys.dm_exec_query_stats AS QS CROSS APPLY
sys.dm_exec_sql_text(QS.sql_handle) AS ST INNER JOIN
( SELECT *
FROM sys.dm_exec_cached_plans cp CROSS APPLY
sys.dm_exec_query_plan(cp.plan_handle)
) DB
ON QS.plan_handle = DB.plan_handle
where SUBSTRING(st.text, ( qs.statement_start_offset / 2 ) + 1,
( ( CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset
END - qs.statement_start_offset ) / 2 ) + 1) not like '%fetch%'
ORDER BY QS.total_elapsed_time / 1000 DESC
现在可以进行相应的优化了,呵呵!
只能想别的方法解决这一问题;
先清除缓存:
dbcc freeProcCache
找出哪些SQL跟数据库还有表对象
SELECT DB_ID(DB.dbid) '数据库名'
, OBJECT_ID(db.objectid) '对象'
, QS.creation_time '编译计划的时间'
, QS.last_execution_time '上次执行计划的时间'
, QS.execution_count '执行的次数'
, QS.total_elapsed_time / 1000 '占用的总时间(秒)'
, QS.total_physical_reads '物理读取总次数'
, QS.total_worker_time / 1000 'CPU 时间总量(秒)'
, QS.total_logical_writes '逻辑写入总次数'
, QS.total_logical_reads N'逻辑读取总次数'
, QS.total_elapsed_time / 1000 N'总花费时间(秒)'
, SUBSTRING(ST.text, ( QS.statement_start_offset / 2 ) + 1,
( ( CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE QS.statement_end_offset
END - QS.statement_start_offset ) / 2 ) + 1) AS '执行语句'
FROM sys.dm_exec_query_stats AS QS CROSS APPLY
sys.dm_exec_sql_text(QS.sql_handle) AS ST INNER JOIN
( SELECT *
FROM sys.dm_exec_cached_plans cp CROSS APPLY
sys.dm_exec_query_plan(cp.plan_handle)
) DB
ON QS.plan_handle = DB.plan_handle
where SUBSTRING(st.text, ( qs.statement_start_offset / 2 ) + 1,
( ( CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset
END - qs.statement_start_offset ) / 2 ) + 1) not like '%fetch%'
ORDER BY QS.total_elapsed_time / 1000 DESC
现在可以进行相应的优化了,呵呵!
相关文章推荐
- sql server性能分析--DMV之(sys.dm_exec_query_stats ) .
- SQL Server 2005 sys.dm_exec_query_stats
- DBA工具——DMV——通过sys.dm_exec_procedure_stats查看存储过程执行信息
- SQL server 2008里面通过sys.dm_exec_procedure_stats得到存储过程的执行信息
- 利用 sys.dm_exec_query_stats 查找并优化SQL语句
- SQL Server查询计划sys.dm_exec_text_query_plan
- DBA工具——DMV——通过sys.dm_exec_procedure_stats查看存储过程执行信息
- sql server数据库占用cpu太大,使用sys.dm_exec_query_stats查询优化
- DBA工具——DMV——通过sys.dm_exec_procedure_stats查看存储过程执行信息
- SQL Server查询计划sys.dm_exec_text_query_plan
- DBA工具——DMV——通过sys.dm_exec_procedure_stats查看存储过程执行信息
- DBA工具——DMV——通过sys.dm_exec_procedure_stats查看存储过程执行信息
- 同一存储过程中各个语句的执行次数不同(sys.dm_exec_query_stats)
- 用sys.dm_exec_query_stats 动态管理查看查询最耗 IO 资源的 SQL 语法
- SQL server 2008里面通过sys.dm_exec_procedure_stats得到存储过程的执行信息
- SQL server 2008里面通过sys.dm_exec_procedure_stats得到存储过程的执行信息
- 对使用sys.dm_exec_query_stats动态视图者的警告(A Warning to Those Using sys.dm_exec_query_stats)
- SQL server 2008里面通过sys.dm_exec_procedure_stats得到存储过程的执行信息--转
- 【SQL 编程你也行】SQL Server 2014新功能之动态视图:sys.dm_exec_query_profiles
- SQL Server 2016里的sys.dm_exec_input_buffer的问题