2025年9月25日: PostgreSQL 18 发布!
支持的版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3

44.5. 触发器函数 #

当函数用作触发器时,字典 TD 包含与触发器相关的数值。

TD["event"]

包含事件作为字符串:INSERTUPDATEDELETETRUNCATE

TD["when"]

包含 BEFOREAFTERINSTEAD OF 中的一个。

TD["level"]

包含 ROWSTATEMENT

TD["new"]
TD["old"]

对于行级触发器,根据触发器事件,这两个字段中的一个或两个包含相应的触发器行。

TD["name"]

包含触发器名称。

TD["table_name"]

包含发生触发器的表的名称。

TD["table_schema"]

包含发生触发器的表的模式。

TD["relid"]

包含发生触发器的表的 OID。

TD["args"]

如果 CREATE TRIGGER 命令包含参数,则它们可在 TD["args"][0]TD["args"][n-1] 中访问。

如果 TD["when"]BEFOREINSTEAD OFTD["level"]ROW,则您可以从 Python 函数返回 None"OK" 来表示行未修改,返回 "SKIP" 来中止事件,或者如果 TD["event"]INSERTUPDATE,则可以返回 "MODIFY" 来表示您已修改新行。否则,返回值将被忽略。

提交更正

如果您在文档中发现任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用此表格报告文档问题。