Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16 / 17

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 OF,且 TD["level"]ROW,则可以从 Python 函数返回 None 或者 "OK",以表明行未修改,返回 "SKIP" 以中止该事件,或者如果 TD["event"]INSERTUPDATE,则可以返回 "MODIFY" 以表明已修改新行。否则将忽略返回值。