postgresql 触发器

java哥 阅读:899 2020-05-08 10:08:02 评论:0

一、创建事件触发器

1、ddl_command_start - 一个DDL开始执行前被触发;

2、ddl_command_end - 一个DLL 执行完成后被触发;

3、sql_drop -- 删除一个数据库对象前被触发;

create or replace function abort_any_command()

returns event_trigger

language plpgsql

as $$

begin

raise exception 'command % is disabled',tg_tag;

end;

$$;

 

create event trigger abort_ddl on DDL_command_start execute procedure abort_any_command();

 

二、语句级触发器

create or replace function log_student_trigger()

returns trigger as $$

begin

insert into log_student values(now(),user,tg_op);

return null;

end;

$$

language plpgsql;

create trigger log_student_trigger

after insert or delete or update on student

for statement execute procedure log_student_trigger;

--此触发器表示,如果对student表进行增、删、改之后将操作日志插入log_student_student表,如果将after替换成before则表示在操作进行之前出发数据插入操作。

注意:语句级的触发器应该总是返回null,并且必须显示地在触发器函数中写上“return null”,如果没写,将会报错。

 

三、修改事件触发器

1、禁用事件触发器 alter event trigger name disable;

2、启用事件触发器 alter event trigger name enable;

3、指定事件触发器所属 alter event trigger name owner to new owner;

4、重命名触发器 alter event trigger name rename to new_name;

 

标签:数据库
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

关注我们

一个IT知识分享的公众号