Postgresql 中文操作指南
46.5. Trigger Functions #
当函数用作触发器时,字典 TD 包含与触发器相关的值:
-
TD["event"]
-
以字符串形式包含事件:INSERT、UPDATE、DELETE 或 TRUNCATE。
-
-
TD["when"]
-
包含 BEFORE、AFTER 或 INSTEAD OF 中的一个。
-
-
TD["level"]
-
contains ROW or STATEMENT.
-
-
TD["new"]__TD["old"]
-
对于行级触发器,根据触发器事件,这两个字段中有一个或两个包含相应的触发器行。
-
-
TD["name"]
-
contains the trigger name.
-
-
TD["table_name"]
-
包含发生触发器的表的名称。
-
-
TD["table_schema"]
-
包含发生触发器的表的模式。
-
-
TD["relid"]
-
包含发生触发器的表的 OID。
-
-
TD["args"]
-
如果 CREATE TRIGGER 命令包含参数,它们在 TD["args"][0] 到 TD["args"][_n-1] _ 中可用。
-
如果 TD["when"] 是 BEFORE 或 INSTEAD OF,并且 TD["level"] 是 ROW,则您可以从 Python 函数返回 None 或 "OK" 以指示该行未修改,"SKIP" 以中止事件,或者如果 TD["event"] 是 INSERT 或 UPDATE,则可以返回 "MODIFY" 以表明您已修改新行。否则,将忽略返回值。