谁能帮我找到下面给出的长时间运行查询的详细信息。
进程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脚本。

#2 楼

我强烈建议sp_whoisactive。它是一个第三方SP,但可以告诉您上面列出的所有内容,并且不仅限于此。这是您武器库中不可思议的工具。