更新触发器未在 plpgsql 中触发
Update trigger not firing in plpgsql
我在 table nums 上有一个更新触发器和插入触发器,其中有两列,即 name,number。只要更新或插入数据,就会执行这些触发器。
CREATE OR REPLACE FUNCTION add_log()
RETURNS trigger AS
$BODY$
DECLARE
account_type varchar;
BEGIN
IF (TG_OP = 'INSERT') THEN
INSERT INTO log
VALUES(
now(),
'inserted data is name : '||NEW.name||' num : '||NEW.number
);
RETURN NEW;
ELSEIF (TG_OP = 'update') THEN
INSERT INTO log VALUES
(
now(),
'updated record with old num :'||OLD.number||' with new num : '||NEW.number
);
RETURN OLD;
END IF;
RETURN null;
END;
$BODY$
LANGUAGE plpgsql
正在创建触发器:
CREATE TRIGGER add_log_trigger
AFTER INSERT OR UPDATE
ON nums
FOR EACH ROW
EXECUTE PROCEDURE add_log();
执行插入操作时,插入触发器fired.But执行更新操作时,没有更新触发器fired.Why?
字符串比较在 Postgres 中区分大小写。尝试 TG_OP = 'UPDATE'
而不是 TG_OP = 'update'
.
我在 table nums 上有一个更新触发器和插入触发器,其中有两列,即 name,number。只要更新或插入数据,就会执行这些触发器。
CREATE OR REPLACE FUNCTION add_log()
RETURNS trigger AS
$BODY$
DECLARE
account_type varchar;
BEGIN
IF (TG_OP = 'INSERT') THEN
INSERT INTO log
VALUES(
now(),
'inserted data is name : '||NEW.name||' num : '||NEW.number
);
RETURN NEW;
ELSEIF (TG_OP = 'update') THEN
INSERT INTO log VALUES
(
now(),
'updated record with old num :'||OLD.number||' with new num : '||NEW.number
);
RETURN OLD;
END IF;
RETURN null;
END;
$BODY$
LANGUAGE plpgsql
正在创建触发器:
CREATE TRIGGER add_log_trigger
AFTER INSERT OR UPDATE
ON nums
FOR EACH ROW
EXECUTE PROCEDURE add_log();
执行插入操作时,插入触发器fired.But执行更新操作时,没有更新触发器fired.Why?
字符串比较在 Postgres 中区分大小写。尝试 TG_OP = 'UPDATE'
而不是 TG_OP = 'update'
.