Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/typo3/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server DMF sys.dm_exec_sql_文本不显示DBID_Sql Server_Performance_Tsql_Sql Server 2012_Dmv - Fatal编程技术网

Sql server DMF sys.dm_exec_sql_文本不显示DBID

Sql server DMF sys.dm_exec_sql_文本不显示DBID,sql-server,performance,tsql,sql-server-2012,dmv,Sql Server,Performance,Tsql,Sql Server 2012,Dmv,我从你那里得到这个问题 当我执行它时,dbid字段返回为null。 为什么会这样? 我想限制来自一个数据库的查询,但它似乎不起作用 非常感谢您的回答。我在Microsoft connect上找到了这个。它解释了dbid可以通过以下方式为null: Sql_handle是一个哈希值,用于标识提交到服务器的批处理的Sql文本。因为它只标识文本,所以可以针对不同的数据库提交,并且仍然是相同的。因此,sql_句柄无法唯一地标识针对特定语句提交此批处理/查询的数据库 另一方面,存储过程总是有它所在的数据

我从你那里得到这个问题

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

非常感谢您的回答。

我在Microsoft connect上找到了这个。它解释了
dbid
可以通过以下方式为null:

Sql_handle是一个哈希值,用于标识提交到服务器的批处理的Sql文本。因为它只标识文本,所以可以针对不同的数据库提交,并且仍然是相同的。因此,sql_句柄无法唯一地标识针对特定语句提交此批处理/查询的数据库

另一方面,存储过程总是有它所在的数据库,因此我们可以填充此列

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

2) 为什么sys.dm\u exec\u sql\u text.dbid有时有空值

  • 在SQL2005->SQL2008R2
    dbid
    中,“对于临时的和准备好的SQL语句”(有关详细信息,请参阅MSDN)为空
  • 在SQL 2012中,“对于临时和准备好的SQL语句,是编译语句的数据库的ID”(请参阅)。因此,从SQL2012开始,dbid将返回一个非空值,包括“临时和准备好的SQL语句”
3) 为了在SQL2008->SQL2008R2中解决这个问题,我使用了
sys.dm_exec_plan_attributes
(请参阅)


你的意思是我应该使用use?不,我认为对于某些类型的查询,它永远不会返回
dbid
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;
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