问题报告 纠错本页面

34.54. triggers

视图triggers包含了所有在当前数据库中的表和视图上定义的, 并且当前用户是其所有者或有除了SELECT之外的某些权限的触发器。

表 34-52. triggers 字段

名字数据类型描述
trigger_catalogsql_identifier包含该触发器的数据库名称(总是当前数据库)
trigger_schemasql_identifier包含该触发器的模式名称
trigger_namesql_identifier触发器名称
event_manipulationcharacter_data 激发触发器的事件(INSERT,UPDATE或者DELETE
event_object_catalogsql_identifier 包含触发器定义所在表的数据库名称(总是当前数据库)
event_object_schemasql_identifier包含触发器定义所在表的模式名
event_object_tablesql_identifier触发器定义所在的表名
action_ordercardinal_number尚未实现
action_conditioncharacter_data WHEN触发器条件,如果没有则为空 (如果当前角色不是该表的所有者也为空)
action_statementcharacter_data 触发器执行的语句(目前总是EXECUTE PROCEDURE function(...)
action_orientationcharacter_data 标识触发器是对处理的每一行激发还是对每个语句激发 (ROW或者STATEMENT
action_timingcharacter_data 触发器触发的时间(BEFOREAFTER或者INSTEAD OF
action_reference_old_tablesql_identifier应用于一个PostgreSQL里没有的特性
action_reference_new_tablesql_identifier应用于一个PostgreSQL里没有的特性
action_reference_old_rowsql_identifier应用于一个PostgreSQL里没有的特性
action_reference_new_rowsql_identifier应用于一个PostgreSQL里没有的特性
createdtime_stamp应用于一个PostgreSQL里没有的特性

PostgreSQL里面的触发器在影响到信息模式的表现形式方面, 与 SQL 标准有两处不同。首先,在PostgreSQL里,触发器名字是表示本地的对象, 而不是独立的模式对象。因此,我们可以在一个模式里定义重复的触发器名字,只要他们属于不同的表。 (trigger_catalogtrigger_schema实际上是属于触发器定义所在表的值。) 第二,PostgreSQL里的触发器可以定义为在多个事件上触发 (比如ON INSERT OR UPDATE),而 SQL 标准只允许一个。 如果一个触发器定义为在多个事件上触发,那么在信息模式里它会表现为多行,事件的每个类型一行。因为这两个原因, 视图triggers的主键实际上是(trigger_catalog, trigger_schema, event_object_table, trigger_name, event_manipulation),而不是(trigger_catalog, trigger_schema, trigger_name), 后者是 SQL 标准声明的。当然,如果你定义一个遵循 SQL 标准的触发器(触发器名字在模式中唯一, 并且每个触发器只有一个事件类型),这些事情不会烦着你。

注意: PostgreSQL 9.1之前,这个视图的字段 action_timing, action_reference_old_table, action_reference_new_table, action_reference_old_row, 和 action_reference_new_row分别叫做 condition_timing, condition_reference_old_table, condition_reference_new_table, condition_reference_old_row, 和 condition_reference_new_row。 这是它们在SQL:1999标准中的名字。新的名字符合SQL:2003和之后的标准。