【发布时间】:2011-03-04 19:16:37
【问题描述】:
如果我有 SPID,我如何找到正在执行的关联查询。由于进程似乎已挂起,因此试图找出关联的查询。
【问题讨论】:
-
您使用的是什么版本的 SQL Server?
标签: sql-server spid
如果我有 SPID,我如何找到正在执行的关联查询。由于进程似乎已挂起,因此试图找出关联的查询。
【问题讨论】:
标签: sql-server spid
--Find Current SQL Statements that are Running
SELECT SPID = er.session_id
,STATUS = ses.STATUS
,[Login] = ses.login_name
,Host = ses.host_name
,BlkBy = er.blocking_session_id
,DBName = DB_Name(er.database_id)
,CommandType = er.command
,ObjectName = OBJECT_NAME(st.objectid)
,CPUTime = er.cpu_time
,StartTime = er.start_time
,TimeElapsed = CAST(GETDATE() - er.start_time AS TIME)
,SQLStatement = st.text
FROM sys.dm_exec_requests er
OUTER APPLY sys.dm_exec_sql_text(er.sql_handle) st
LEFT JOIN sys.dm_exec_sessions ses
ON ses.session_id = er.session_id
LEFT JOIN sys.dm_exec_connections con
ON con.session_id = ses.session_id
WHERE st.text IS NOT NULL
【讨论】:
什么版本的sql server? 2000 年及以上你可以做到
dbcc inputbuffer (spid)
这将给出前 255 个字符
将 spid 替换为 spid 的数字
对于 2005 年及更高版本,将 @@SPID 更改为您要查找的 spid
select dest.*
from sys.dm_exec_requests as der
cross apply sys.dm_exec_sql_text (der.sql_handle) as dest
where session_id = @@spid
【讨论】:
假设 SQL Server 2005+
SELECT
CASE
WHEN statement_end_offset = -1
THEN text
ELSE SUBSTRING(text,statement_start_offset/2,(statement_end_offset- statement_start_offset)/2)
END, *
FROM sys.dm_exec_requests
CROSS APPLY sys.dm_exec_sql_text(sql_handle)
WHERE session_id = <whatever>
您可能想要下载“Who is Active?”程序,它汇集了比这更多的信息。
【讨论】:
如果您在活动监视器中查看它,您应该能够通过右键单击并选择“详细信息”找到与 SPID 关联的 SQL。
以下是一些帮助您入门的链接:
你也可以从那里杀死它作为最后的手段。
【讨论】: