sql-server - DMF sys.dm_exec_sql_text 不显示 DBID

标签 sql-server performance tsql sql-server-2012 dmv

我从

收到此查询

http://technet.microsoft.com/en-us/library/ms181929.aspx

SELECT s2.dbid, 
    s1.sql_handle,  
    (SELECT TOP 1 SUBSTRING(s2.text,statement_start_offset / 2+1 , 
      ( (CASE WHEN statement_end_offset = -1 
         THEN (LEN(CONVERT(nvarchar(max),s2.text)) * 2) 
         ELSE statement_end_offset END)  - statement_start_offset) / 2+1))  AS sql_statement,
    execution_count, 
    plan_generation_num, 
    last_execution_time,   
    total_worker_time, 
    last_worker_time, 
    min_worker_time, 
    max_worker_time,
    total_physical_reads, 
    last_physical_reads, 
    min_physical_reads,  
    max_physical_reads,  
    total_logical_writes, 
    last_logical_writes, 
    min_logical_writes, 
    max_logical_writes  
FROM sys.dm_exec_query_stats AS s1 
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2  
WHERE s2.objectid is null 
ORDER BY s1.sql_handle, s1.statement_start_offset, s1.statement_end_offset;

当我执行它时,dbid 字段返回为空。 enter image description here 为什么会有这样的行为? 我想限制来自一个数据库的查询,但它似乎不起作用。

非常感谢您的回答。

最佳答案

1) 此行为在 SQL2005 -> SQL2008R2 中可用。

2) 为什么sys.dm_exec_sql_text.dbid(有时)有NULL?

  • 在 SQL2005 -> SQL2008R2 中,dbid 为 NULL“对于临时和准备好的 SQL 语句”(请参阅​​ MSDN 的 SQL Server 2008 R2 )。
  • 在 SQL 2012 中,“对于即席和准备好的 SQL 语句,编译语句的数据库的 ID”(请参阅​​ MSDN )。因此,从 SQL2012 开始 dbid 将返回一个非 NULL 值,包括“临时和准备好的 SQL 语句”。

3)为了解决 SQL2008 -> SQL2008R2 中的这个问题,我使用了 sys.dm_exec_plan_attributes (参见 MSDN )

SELECT ..., ISNULL(s2.dbid,CONVERT(SMALLINT,att.value)) AS my_dbid, ...
FROM sys.dm_exec_query_stats AS s1 
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2 
CROSS APPLY sys.dm_exec_plan_attributes(s1.plan_handle) att
WHERE att.attribute='dbid

关于sql-server - DMF sys.dm_exec_sql_text 不显示 DBID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20172267/

相关文章:

sql - 在 Cursor 中选择查询花费的时间太长

sql-server - 如果记录不存在,插入记录的最佳做法是什么?

mysql - JOIN 或 LEFT JOIN 是否持续检查 SELECT 查询?

sql - 为每个导致效率问题的键找到最小值

javascript - PerformanceTiming.responseStart 是指向 HTML 还是 headers 开始?

SQL:WHERE 子句中的 IF 子句

sql - SQL中的一个思想实验

sql-server - 如何检查上次更新数据库表的时间

sql-server - 为什么除零后执行insert into语句会抛出异常

sql - 将 JSON 字符串转换为十进制的问题