PostgreSQL 创建触发器 Trigger
时间:2022-03-15 08:24
触发器的知识点:
-
PostgreSQL在以下情况下执行/调用触发器:在尝试操作之前(在检查约束并尝试
INSERT
,UPDATE
或DELETE
之前)。或者在操作完成后(在检查约束并且INSERT
,UPDATE
或DELETE
完成后)。或者不是操作(在视图中INSERT
,UPDATE
或DELETE
的情况下) -
对于操作修改的每一行,都会调用一个标记为
FOR EACH ROWS
的触发器。 另一方面,标记为FOR EACH STATEMENT
的触发器只对任何给定的操作执行一次,而不管它修改多少行。 -
您可以为同一事件定义同一类型的多个触发器,但条件是按名称按字母顺序触发。
- 当与它们相关联的表被删除时,触发器被自动删除。
step1: 创建记录日志表, 跟踪记录表上的所有操作
create table auditlog
(
operation varchar(100),
id int,
productname varchar(100),
catagoryid int,
subcatagoryid int,
operationdate timestamp without time zone
)
step2: 创建触发器相关的存储过程
CREATE FUNCTION public.auditinsertfunlog()
RETURNS trigger
LANGUAGE ‘plpgsql‘
COST 100
VOLATILE NOT LEAKPROOF
ROWS 0
AS $BODY$
begin
insert into auditlog (operation,id,productname,catagoryid,subcatagoryid,operationdate)
values(‘insert‘,new.id,new."productName",new."catagoryID",new."subcatagoryID",current_timestamp);
return new;
end;
$BODY$;
ALTER FUNCTION public.auditinsertfunlog()
OWNER TO postgres;
step3: 创建触发器
CREATE TRIGGER products_insert_trigger
AFTER INSERT ON public."Products"
FOR EACH ROW EXECUTE PROCEDURE public.auditinsertfunlog();