/**PageBeginHtml Block Begin **/ /***自定义返回顶部小火箭***/ /*生成博客目录的JS 开始*/ /*生成博客目录的JS 结束*/

SQLServer查询历史执行记录的方法实现

* 博客文章部分截图及内容来自于学习的书本及相应培训课程以及网络其他博客,仅做学习讨论之用,不做商业用途。
* 如有侵权,马上联系我,我立马删除对应链接。
* @author Alan
* @Email no008@foxmail.com

 

正文





1. 使用 SQL Server Management Studio (SSMS) 的查询执行记录功能:

  • 打开 SSMS,连接到要查看执行记录的数据库服务器。
  • 在“对象资源管理器”窗格中,右键单击要查看执行记录的数据库,然后选择“报表” > “标准报表” > “执行记录”。
  • 在“执行记录”窗口中,选择要查看的时间范围和其他过滤条件,然后单击“运行”。

2. 使用系统视图:

  • 在 SQL Server Management Studio (SSMS) 中打开“新查询”窗口。

  • 运行以下 SQL 查询语句来查看最近的执行记录:

SELECT TOP 100 *

FROM sys.dm_exec_query_stats AS qs

CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS st

ORDER BY last_execution_time DESC;
这将显示最近的 100 个执行记录,按最后执行时间的降序排列。您可以根据需要更改 TOP 数量和排序顺序。
  • 也可以看部分关键执行字段:

 

复制代码
SELECT TOP 100

qs.last_execution_time,

DB_NAME(st.dbid) AS database_name,

OBJECT_NAME(st.objectid, st.dbid) AS object_name,

SUBSTRING(st.text, (qs.statement_start_offset/2)+1,

((CASE qs.statement_end_offset

WHEN -1 THEN DATALENGTH(st.text)

ELSE qs.statement_end_offset

END - qs.statement_start_offset)/2)+1) AS executed_sql

FROM sys.dm_exec_query_stats AS qs

CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS st

ORDER BY qs.last_execution_time DESC;
复制代码
这个查询语句将返回最近执行的 100 个查询,并包括执行时间、所在的数据库名称、对象名称和实际执行的 SQL 语句。其中 SUBSTRING 函数用于从完整的 SQL 语句文本中提取实际执行的部分。









posted @   一品堂.技术学习笔记  阅读(741)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤
历史上的今天:
2022-01-25 Java 所有版本的jdk下载
2019-01-25 动态的加载显示oracle警告日志文件内容
点击右上角即可分享
微信分享提示

目录导航