进程ID,进程名称,数据库,主机,用户,进程登录时间,查询开始时间和查询持续时间。
我正在寻找给我这些数据的查询或SP。
#1 楼
如前所述,最好的工具是Adam Machanic的sp_whoIsActive。它可以以多种方式使用,以查看启动脚本时正在运行的内容,也可以循环运行以监视某些特定操作,例如慢速查询。要循环运行,请执行以下操作在这里查看:如何在循环中使用sp_whoisactive记录活动
要检测慢查询:如何使用sp_WhoIsActive查找慢的SQL Server查询
您可以直接使用DMV获取最慢的查询并从那里执行操作。检查Glenn Berry的诊断查询。
最后,您可以使用此查询查找最耗时的查询。您可以使用dm_exec_query_stats来添加更多数据,或与其他数据一起获取更多信息。请注意,每次重新启动服务器时,dmv都会被刷新并刷新。
SELECT creation_time
,last_execution_time
,total_physical_reads
,total_logical_reads
,total_logical_writes
, execution_count
, total_worker_time
, total_elapsed_time
, total_elapsed_time / execution_count avg_elapsed_time
,SUBSTRING(st.text, (qs.statement_start_offset/2) + 1,
((CASE statement_end_offset
WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset END
- qs.statement_start_offset)/2) + 1) AS statement_text
FROM sys.dm_exec_query_stats AS qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) st
ORDER BY total_elapsed_time / execution_count DESC;
编辑
从某个时候开始,一个新的选项,即第一响应程序工具包已经可用。是一组脚本,由BrentOzar团队根据麻省理工学院的许可免费提供,可帮助完成各种任务,包括OP要求的脚本。在这种情况下,主要是sp_BlitzFirst和sp_BlitzWho脚本。