Как найти, что связано с запросом, который выполняется, если у меня есть SPID. Попытка выяснить, какой запрос связывается, поскольку процесс, кажется, висел.
SQL Server - процесс подвески - запрос SPID
Ответ 1
какая версия сервера 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
Ответ 2
--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
Ответ 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
Если вы посмотрите на монитор активности, вы сможете найти SQL, связанный с SPID, щелкнув правой кнопкой мыши и выбрав "details".
Вот несколько ссылок, которые помогут вам начать:
- http://support.microsoft.com/kb/298475
- http://msdn.microsoft.com/en-us/library/ms188272.aspx
- http://msdn.microsoft.com/en-us/library/ms175518.aspx
Вы также можете убить его оттуда в качестве последнего средства.