我从
获得此查询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字段返回null。 为什么这样做? 我想限制来自一个数据库的查询,但似乎无效。
非常感谢你的回答。
答案 0 :(得分:5)
1)SQL2005中提供了此行为 - > SQL2008R2。
2)为什么sys.dm_exec_sql_text.dbid
(有时)有NULL?
dbid
为NULL“(请参阅MSDN for SQL Server 2008 R2)。 dbid
开始将返回非NULL值,包括“ad hoc和准备好的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
答案 1 :(得分:1)
我在Microsoft connect上发现了这个this post。它解释了dbid
可以通过以下方式为空:
Sql_handle是一个哈希值,用于标识提交给服务器的批处理的SQL文本。由于它只标识文本,因此可以针对不同的数据库提交,并且仍然是相同的。因此,sql_handle无法唯一地标识针对ad-hoc语句针对此批处理/查询提交的数据库。
另一方面,存储过程始终拥有它所在的数据库,因此我们可以填充此列。