SQL Server - 挂起进程 - SPID查询

时间:2011-03-04 19:16:38

标签: sql-server spid

如果我有SPID,如何找到正在执行的关联查询。试图找出关联的查询,因为该过程似乎已挂起。

4 个答案:

答案 0 :(得分:13)

--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

答案 1 :(得分:12)

什么版本的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

答案 2 :(得分:3)

假设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?”程序,该程序汇总了更多信息。

答案 3 :(得分:1)

如果您在活动监视器中查看它,您应该能够通过右键单击并选择“详细信息”来找到与SPID关联的SQL。

以下是一些可以帮助您入门的链接:

你也可以从那里杀死它作为最后的手段。