多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
# 9.28\. 事件触发函数 当前PostgreSQL提供一个内建的事件触发帮助函数 `pg_event_trigger_dropped_objects`。 `pg_event_trigger_dropped_objects`返回一个在`sql_drop` 事件中调用的命令删除的所有对象的列表。如果在任何其他上下文中调用, `pg_event_trigger_dropped_objects`将抛出一个错误。 `pg_event_trigger_dropped_objects`返回下列的字段: | 名字 | 类型 | 描述 | | --- | --- | --- | | `classid` | `Oid` | 对象所在的目录的OID | | `objid` | `Oid` | 目录中对象的OID | | `objsubid` | `int32` | 对象的sub-id(例如,字段的属性个数) | | `object_type` | `text` | 对象的类型 | | `schema_name` | `text` | 如果有,为对象所在模式的名字;否则为`NULL`。不用双引号。 | | `object_name` | `text` | 如果模式和名字的组合可以用来唯一的标识对象,那么就是对象的名字;否则为`NULL`。 不用双引号,并且名字是从不模式限定的。 | | `object_identity` | `text` | 对象身份的文本表现,模式限定的。每个标识符在身份中出现时要在必要时引用。 | `pg_event_trigger_dropped_objects` 函数可以在一个事务触发器中使用: ``` CREATE FUNCTION test_event_trigger_for_drops() RETURNS event_trigger LANGUAGE plpgsql AS $$ DECLARE obj record; BEGIN FOR obj IN SELECT * FROM pg_event_trigger_dropped_objects() LOOP RAISE NOTICE '% dropped object: % %.% %', tg_tag, obj.object_type, obj.schema_name, obj.object_name, obj.object_identity; END LOOP; END $$; CREATE EVENT TRIGGER test_event_trigger_for_drops ON sql_drop EXECUTE PROCEDURE test_event_trigger_for_drops(); ``` 关于事务触发器的更多信息请参阅[Chapter 37](#calibre_link-580)。