sys.dm_exec_trigger_stats (Transact-SQL)
适用于: SQL Server Azure SQL 数据库 Azure SQL 托管实例
返回缓存触发器的聚合性能统计信息。 每个触发器在该视图中对应一行,行的生存期与触发器保持缓存状态的时间一样长。 在从缓存中删除触发器时,也将从该视图中删除对应行。 此时,将引发类似于 sys.dm_exec_query_stats 的性能统计信息 SQL 跟踪事件。
列名称 | 数据类型 | 描述 |
---|---|---|
database_id | int | 触发器所在的数据库 ID。 在 Azure SQL 数据库中,这些值在单一数据库或弹性池中是唯一的,但在逻辑服务器中不是唯一的。 |
object_id | int | 触发器的对象标识号。 |
type | char(2) | 对象的类型: TA = 程序集 (CLR) 触发器 TR = SQL 触发器 |
Type_desc | nvarchar(60) | 对对象类型的说明: CLR_TRIGGER SQL_TRIGGER |
sql_handle | varbinary(64) | 这可用于与从此触发器内执行的sys.dm_exec_query_stats中的查询相关联。 |
plan_handle | varbinary(64) | 内存中计划的标识符。 该标识符是瞬态的,仅当计划保留在缓存中时,它才保持不变。 此值可与 sys.dm_exec_cached_plans 动态管理视图一起使用。 |
cached_time | datetime | 触发器添加到缓存的时间。 |
last_execution_time | datetime | 上次执行触发器的时间。 |
execution_count | bigint | 自上次编译触发器以来已执行的次数。 |
total_worker_time | bigint | 自编译此触发器以来执行的 CPU 总时间(以微秒为单位)。 |
last_worker_time | bigint | 上次执行触发器所用的 CPU 时间(微秒)。 |
min_worker_time | bigint | 此触发器在单个执行期间使用的最大 CPU 时间(以微秒为单位)。 |
max_worker_time | bigint | 此触发器在单个执行期间使用的最大 CPU 时间(以微秒为单位)。 |
total_physical_reads | bigint | 自编译此触发器以来执行的物理读取总数。 |
last_physical_reads | bigint | 上次执行触发器时执行的物理读取数。 |
min_physical_reads | bigint | 此触发器在单个执行期间执行过的最小物理读取次数。 |
max_physical_reads | bigint | 此触发器在单个执行期间执行的最大物理读取次数。 |
total_logical_writes | bigint | 自编译此触发器以来执行的逻辑写入总数。 |
last_logical_writes | bigint | 上次执行触发器时执行的逻辑写入数。 |
min_logical_writes | bigint | 此触发器在单个执行期间执行过的最小逻辑写入数。 |
max_logical_writes | bigint | 此触发器在单个执行期间执行的最大逻辑写入数。 |
total_logical_reads | bigint | 自编译此触发器以来执行的逻辑读取总数。 |
last_logical_reads | bigint | 上次执行触发器时执行的逻辑读取数。 |
min_logical_reads | bigint | 此触发器在单个执行期间执行过的最小逻辑读取数。 |
max_logical_reads | bigint | 此触发器在单个执行期间执行的最大逻辑读取数。 |
total_elapsed_time | bigint | 完成此触发器执行的总运行时间(以微秒为单位)。 |
last_elapsed_time | bigint | 最近完成此触发器的执行所用的时间(微秒)。 |
min_elapsed_time | bigint | 对于此触发器的任何已完成执行,最短时间(以微秒为单位)。 |
max_elapsed_time | bigint | 此触发器执行完成的最大时间(以微秒为单位)。 |
total_spills | bigint | 自编译以来,此触发器的执行所溢出的页总数。 适用于:从 SQL Server 2017(14.x) CU3 开始 |
last_spills | bigint | 上次执行触发器时溢出的页数。 适用于:从 SQL Server 2017(14.x) CU3 开始 |
min_spills | bigint | 此触发器在单个执行期间溢出的最小页数。 适用于:从 SQL Server 2017(14.x) CU3 开始 |
max_spills | bigint | 此触发器在单个执行期间溢出的最大页数。 适用于:从 SQL Server 2017(14.x) CU3 开始 |
total_page_server_reads | bigint | 自编译以来,此触发器的执行所执行的页服务器读取总数。 适用范围:Azure SQL 数据库超大规模 |
last_page_server_reads | bigint | 上次执行触发器时执行的页服务器读取次数。 适用范围:Azure SQL 数据库超大规模 |
min_page_server_reads | bigint | 此触发器在单个执行期间执行过的最小页服务器读取次数。 适用范围:Azure SQL 数据库超大规模 |
max_page_server_reads | bigint | 此触发器在单个执行期间执行的最大页服务器读取次数。 适用范围:Azure SQL 数据库超大规模 |
注解
在SQL 数据库中,动态管理视图无法公开影响数据库包含或公开用户有权访问的其他数据库的信息。 为了避免暴露此信息,包含不属于所连接租户的数据的每行都会被筛选出。
查询完成后,将更新该视图中的统计信息。
权限
对于 SQL Server 和 SQL 托管实例,需要 VIEW SERVER STATE
权限。
在 SQL 数据库“基本”、“S0”和“S1”服务目标中,对于“弹性池”中的数据库,服务器管理员帐户、Microsoft Entra 管理员帐户或 ##MS_ServerStateReader##
服务器角色中的成员身份为必填项。 对于所有其他 SQL 数据库服务目标,需要数据库的 VIEW DATABASE STATE
权限或 ##MS_ServerStateReader##
服务器角色中的成员身份。
SQL Server 2022 及更高版本的权限
要求对服务器具有 VIEW SERVER PERFORMANCE STATE 权限。
示例
以下示例返回有关按平均占用时间衡量的前五个触发器的信息。
SELECT TOP 5 d.object_id, d.database_id, DB_NAME(database_id) AS 'database_name',
OBJECT_NAME(object_id, database_id) AS 'trigger_name', d.cached_time,
d.last_execution_time, d.total_elapsed_time,
d.total_elapsed_time/d.execution_count AS [avg_elapsed_time],
d.last_elapsed_time, d.execution_count
FROM sys.dm_exec_trigger_stats AS d
ORDER BY [total_worker_time] DESC;
另请参阅
与执行有关的动态管理视图和函数 (Transact-SQL)
sys.dm_exec_sql_text (Transact-SQL)
sys.dm_exec_query_stats (Transact-SQL)
sys.dm_exec_procedure_stats (Transact-SQL)
sys.dm_exec_cached_plans (Transact-SQL)