SQL Server簡潔查詢正在執行SQL(等待事件)

zping發表於2016-04-14

通常我們可以使用

sp_who2

       我們希望更加簡潔的資訊,下面這個查詢使用系統表sys.sysprocesses,以及sys.dm_exec_sql_text做OUTER APPLY. T-SQL是這樣的:      

SELECT   spid,
         blocked,
         DB_NAME(sp.dbid) AS DBName,
         program_name,
         waitresource,
		 sp.waittime,
		 sp.stmt_start,
         lastwaittype,
         sp.loginame,
		 sp.Status,
         sp.hostname,
         a.[Text] AS [TextData],
         SUBSTRING(A.text, sp.stmt_start / 2,
         (CASE WHEN sp.stmt_end = -1 THEN DATALENGTH(A.text) ELSE sp.stmt_end
         END - sp.stmt_start) / 2) AS [current_cmd]
FROM     sys.sysprocesses AS sp OUTER APPLY sys.dm_exec_sql_text (sp.sql_handle) AS A
WHERE    spid > 50 and lastwaittype='HADR_SYNC_COMMIT'             
ORDER BY blocked DESC, DB_NAME(sp.dbid) ASC, a.[text];

  上面可以檢視正在執行的sql,他的等待事件 

         您可能注意到過濾了spid小於50的,這裡有TextData,Current_cmd兩列,可以列出當前DataBase執的SQL文字,當然您拿到spid就可以使用更多的查詢。 

      以便於您定位阻塞的程式。

        

檢視中主要的欄位:
1. Spid:Sql Servr 會話ID
2. Kpid:Windows 執行緒ID
3. Blocked:正在阻塞求情的會話 ID。如果此列為 Null,則標識請求未被阻塞
4. Waittype:當前連線的等待資源編號,標示是否等待資源,0 或 Null表示不需要等待任何資源
5. Waittime:當前等待時間,單位為毫秒,0 表示沒有等待
6. DBID:當前正由程式使用的資料庫ID
7. UID:執行命令的使用者ID
8. Login_time:客戶端程式登入到伺服器的時間。
9. Last_batch:上次執行儲存過程或Execute語句的時間。對於系統程式,將儲存Sql Server 的啟動時間
10.Open_tran:程式的開啟事務個數。如果有巢狀事務,就會大於1
11.Status:程式ID 狀態,dormant = 正在重置回話 ; running = 回話正在執行一個或多個批處理 ; background = 回話正在執行一個後臺任務 ; rollback = 會話正在處理事務回滾 ; pending = 回話正在等待工作現成變為可用 ; runnable = 會話中的任務在等待獲取 Scheduler 來執行的可執行佇列中 ; spinloop = 會話中的任務正在等待自旋鎖變為可用 ; suspended = 會話正在等待事件完成
12.Hostname:建立連結的客戶端工作站的名稱
13.Program_name:應用程式的名稱,就是 連線字串中配的 Application Name
14.Hostprocess:建立連線的應用程式在客戶端工作站裡的程式ID號
15.Cmd:當前正在執行的命令
16.Loginame:登入名

相關文章