Retorna User, Query, tempo inicio e fim da execução da query
Pessoal, boa tarde.
Preciso da ajuda para compreender um select que estou fazendo.
A consulta é simples, porém estou iniciando na área de SQL a pouco tempo, eu quero trazer todas as consultar executadas no banco por determinado usuário, inicio da execução da consulta e tempo que ficou executando. Segue meu código abaixo, o problema é que ele retorna o usuário e query diferente de outro código que tenho.
Primeira query, (não consegui colocar os usuário):
SELECT
--US.HOSTNAME,
--US.NT_USERNAME,
--US.PROGRAM_NAME,
--US.sql_handle US,
DB_NAME(D.dbid) AS BANCO,
t.[text],
s.last_execution_time,
CONVERT(VARCHAR(12), CONVERT(time, DATEADD(ms, S.TOTAL_WORKER_TIME / 1000000 * 1000, 0)),114) AS TEMPO_TOTAL_EXECUTANDO,
CONVERT(VARCHAR(12), CONVERT(time, DATEADD(ms, S.TOTAL_ELAPSED_TIME / 1000000 * 1000, 0)),114),
S.TOTAL_ROWS
FROM sys.dm_exec_cached_plans AS p
INNER JOIN sys.dm_exec_query_stats AS s
ON p.plan_handle = s.plan_handle
CROSS APPLY sys.dm_exec_sql_text(p.plan_handle) AS t
CROSS APPLY sys.dm_exec_sql_text(S.sql_handle) AS D
--LEFT JOIN sys.sysprocesses US ON US.sql_handle = S.sql_handle
WHERE s.last_execution_time >= '2018-01-17 18:00:00.000' AND s.last_execution_time <= '2018-01-18'
ORDER BY s.last_execution_time
Segunda Query (Peguei na net e adicionei o que eu precisava, porém as querys e user estão diferentes).
SELECT
--sp.host_name AS HOST_USER,
--sp.login_name AS NOME_USUARIO,
T.[text] AS QUERY,
S.last_execution_time AS INICIO_EXECUCAO,
CONVERT(VARCHAR(12), CONVERT(time, DATEADD(ms, S.TOTAL_WORKER_TIME / 1000000 * 1000, 0)),114) AS TEMPO_TOTAL_EXECUTANDO,
CONVERT(VARCHAR(12), CONVERT(time, DATEADD(ms, S.TOTAL_ELAPSED_TIME / 1000000 * 1000, 0)),114) AS TOTAL_ELAPSED,
S.TOTAL_ROWS
FROM sys.dm_exec_requests ER
INNER JOIN
sys.dm_exec_sessions SP ON er.session_id = sp.session_id
CROSS APPLY sys.dm_exec_sql_text(er.sql_handle) as T
CROSS APPLY sys.dm_exec_query_stats AS S
--CROSS APPLY sys.dm_exec_query_plan(er.plan_handle) p
--CROSS APPLY sys.dm_exec_text_query_plan(s.plan_handle, s.statement_start_offset, s.statement_end_offset) as qp
--where sp.session_Id NOT IN (@@SPID)
WHERE s.last_execution_time >= '2018-01-17 18:00:00.000' AND s.last_execution_time <= '2018-01-18'
AND T.[text] <> 'sp_server_diagnostics'
ORDER BY S.last_execution_time
Valew galera.Discussão (1)
Carregando comentários...