SQL Server - процесс зависания - запрос SPID - PullRequest
13 голосов
/ 04 марта 2011

Как мне найти связанный запрос, который выполняется, если у меня есть SPID. Попытка выяснить, какой запрос связан, поскольку процесс кажется зависшим.

Ответы [ 4 ]

14 голосов
/ 28 января 2014
--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
12 голосов
/ 04 марта 2011

какая версия сервера sql? на 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 голосов
/ 04 марта 2011

Предполагается, что 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>

Возможно, вы захотите загрузить процедуру " Кто активен? ", которая объединяет гораздо больше информации, чем эта.

1 голос
/ 04 марта 2011

Если вы посмотрите на него в мониторе активности, вы сможете найти SQL, связанный с SPID, щелкнув правой кнопкой мыши и выбрав «детали».

Вот несколько ссылок, с которых можно начать:

Вы также можете убить его оттуда в крайнем случае.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...