Advertisement
Guest User

Untitled

a guest
Dec 16th, 2013
194
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
SQL 2.60 KB | None | 0 0
  1. SELECT
  2. [Net Address]   = ISNULL(c.client_net_address, N'') ,
  3.    [SESSION ID]    = s.session_id,
  4.    [USER Process]  = CONVERT(CHAR(1), s.is_user_process),
  5.    [Login]         = s.login_name,  
  6.    [DATABASE]      = ISNULL(db_name(p.dbid), N''),
  7.    [Task State]    = ISNULL(t.task_state, N''),
  8.    [Command]       = ISNULL(r.command, N''),
  9.    [Application]   = ISNULL(s.program_name, N''),
  10.    [Wait TIME (ms)]     = ISNULL(w.wait_duration_ms, 0),
  11.    [Wait TYPE]     = ISNULL(w.wait_type, N''),
  12.    [Wait Resource] = ISNULL(w.resource_description, N''),
  13.    [Blocked BY]    = ISNULL(CONVERT (VARCHAR, w.blocking_session_id), ''),
  14.    [Head Blocker]  =
  15.         CASE
  16.             -- session has an active request, is blocked, but is blocking others or session is idle but has an open tran and is blocking others
  17.             WHEN r2.session_id IS NOT NULL AND (r.blocking_session_id = 0 OR r.session_id IS NULL) THEN '1'
  18.             -- session is either not blocking someone, or is blocking someone but is blocked by another party
  19.             ELSE ''
  20.         END,
  21.    [Total CPU (ms)] = s.cpu_time,
  22.    [Total Physical I/O (MB)]   = (s.reads + s.writes) * 8 / 1024,
  23.    [Memory USE (KB)]  = s.memory_usage * 8192 / 1024,
  24.    [OPEN Transactions] = ISNULL(r.open_transaction_count,0),
  25.    [Login TIME]    = s.login_time,
  26.    [LAST Request START TIME] = s.last_request_start_time,
  27.    [Host Name]     = ISNULL(s.host_name, N'')
  28.    
  29.    
  30. FROM sys.dm_exec_sessions s LEFT OUTER JOIN sys.dm_exec_connections c ON (s.session_id = c.session_id)
  31. LEFT OUTER JOIN sys.dm_exec_requests r ON (s.session_id = r.session_id)
  32. LEFT OUTER JOIN sys.dm_os_tasks t ON (r.session_id = t.session_id AND r.request_id = t.request_id)
  33. LEFT OUTER JOIN
  34. (
  35.     -- In some cases (e.g. parallel queries, also waiting for a worker), one thread can be flagged as
  36.     -- waiting for several different threads.  This will cause that thread to show up in multiple rows
  37.     -- in our grid, which we don't want.  Use ROW_NUMBER to select the longest wait for each thread,
  38.     -- and use it as representative of the other wait relationships this thread is involved in.
  39.     SELECT *, ROW_NUMBER() OVER (PARTITION BY waiting_task_address ORDER BY wait_duration_ms DESC) AS row_num
  40.     FROM sys.dm_os_waiting_tasks
  41. ) w ON (t.task_address = w.waiting_task_address) AND w.row_num = 1
  42. LEFT OUTER JOIN sys.dm_exec_requests r2 ON (s.session_id = r2.blocking_session_id)
  43. --LEFT OUTER JOIN sys.dm_resource_governor_workload_groups g ON (g.group_id = s.group_id)
  44. LEFT OUTER JOIN sys.sysprocesses p ON (s.session_id = p.spid)
  45. WHERE s.session_id=285
  46. ORDER BY s.login_name;
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement