内存溢出dmvs

时间:2018-05-15 13:43:03

标签: sql sql-server tsql tempdb dmv

在sql server 2014中,我们可以使用dmvs查找溢出到tempdb的查询吗?

1 个答案:

答案 0 :(得分:0)

当然,只需查询执行计划生成的XML即可。以下查询显示执行计划中出现警告最多的50个执行最差的查询。

溢出在执行计划中显示为警告,就像转换错误一样,您可以通过使计数更具限制性来过滤掉所返回的项目,而不仅仅是在寻找单词 warning 。你也可以寻找表扫描。玩吧。这是查询:

SELECT  [TSQL]= st.text,
        qp.query_plan
FROM    (
    SELECT  TOP 50 *
    FROM    sys.dm_exec_query_stats
    ORDER BY total_worker_time DESC
) AS qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS st
CROSS APPLY sys.dm_exec_query_plan(qs.plan_handle) AS qp
WHERE qp.query_plan.value('declare namespace p="http://schemas.microsoft.com/sqlserver/2004/07/showplan";count(//p:Warnings)', 'int') > 0

enter image description here

第2部分你的问题

从DMV访问您的执行计划允许您查找执行计划中显示的任何内容,例如生成表扫描的查询并忽略索引:

DECLARE @Table_Name sysname = N'Orders';

;WITH XMLNAMESPACES(DEFAULT N'http://schemas.microsoft.com/sqlserver/2004/07/showplan')
SELECT 
 [TSQL]=st.text
,Schema_Name=operators.value('(TableScan/Object/@Schema)[1]','sysname')
,[Table]=operators.value('(TableScan/Object/@Table)[1]','sysname')
,[Index]=operators.value('(TableScan/Object/@Index)[1]','sysname')
,[Physical]= operators.value('@PhysicalOp','nvarchar(50)')
,[Occurance]= cp.usecounts
,qp.query_plan
FROM sys.dm_exec_cached_plans cp
CROSS APPLY sys.dm_exec_query_plan(cp.plan_handle) qp
CROSS APPLY sys.dm_exec_sql_text(cp.plan_handle) AS st
CROSS APPLY query_plan.nodes('//RelOp') rel(operators)
WHERE operators.value('@PhysicalOp','nvarchar(60)') IN ('Table Scan')
AND operators.value('(TableScan/Object/@Table)[1]','sysname') = QUOTENAME(@Table_Name,'[');

前一段时间从SQLTips拉出原文,并且适用于大多数版本,只需确保执行计划包含您正在寻找的数据。

也许分享您正在使用的计划和SQL版本。