我从
收到此查询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 字段返回为空。 为什么会有这样的行为? 我想限制来自一个数据库的查询,但它似乎不起作用。
非常感谢您的回答。
最佳答案
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/