阅读量:1
在SQL Server中,可以通过查询系统表来获取历史SQL执行记录。以下是一些常用的系统表和视图:
- sys.dm_exec_query_stats:该视图返回有关最近执行的查询的统计信息,包括查询的执行计划、CPU使用情况、内存使用情况等。
SELECT * FROM sys.dm_exec_query_stats
- sys.dm_exec_sql_text:该视图返回有关SQL语句的详细信息,包括SQL文本和语句的执行计划。
SELECT * FROM sys.dm_exec_sql_text(PLAN_HANDLE)
其中PLAN_HANDLE
是从sys.dm_exec_query_stats
视图中获取的执行计划句柄。
- sys.dm_exec_requests:该视图返回有关当前执行的请求的信息,包括正在执行的SQL语句、进度、等待类型等。
SELECT * FROM sys.dm_exec_requests
- sys.dm_exec_sessions:该视图返回有关当前连接到SQL Server的会话的信息,包括会话ID、登录名、应用程序名称等。
SELECT * FROM sys.dm_exec_sessions
- sys.dm_exec_connections:该视图返回有关当前连接到SQL Server的连接的信息,包括连接ID、客户端IP地址、连接状态等。
SELECT * FROM sys.dm_exec_connections
- sys.dm_exec_query_plan:该函数返回给定SQL语句的执行计划。
SELECT * FROM sys.dm_exec_query_plan(PLAN_HANDLE)
其中PLAN_HANDLE
是从sys.dm_exec_query_stats
视图中获取的执行计划句柄。
请注意,这些系统表和视图中的数据只会在SQL Server的内存中保留一段时间,一旦SQL Server重启或者缓存被清空,这些历史记录会丢失。如果需要长期保存历史SQL执行记录,可以考虑使用SQL Server的追踪功能或第三方工具。