【问题标题】:SQL Server - Hanging Process - SPID QuerySQL Server - 挂起进程 - SPID 查询
【发布时间】:2011-03-04 19:16:37
【问题描述】:

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

【问题讨论】:

  • 您使用的是什么版本的 SQL Server?

标签: sql-server spid


【解决方案1】:
--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

【讨论】:

    【解决方案2】:

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

    【讨论】:

      【解决方案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?”程序,它汇集了比这更多的信息。

      【讨论】:

        【解决方案4】:

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

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

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

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2010-11-13
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2018-09-08
          • 1970-01-01
          相关资源
          最近更新 更多