Skip to content

46.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"以指示你已修改新行。否则将忽略返回值。