Postgresql 中文操作指南

46.5. Trigger Functions #

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

  • TD["event"]

    • 以字符串形式包含事件:INSERTUPDATEDELETETRUNCATE

  • TD["when"]

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