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

44.5. 触发器函数 #

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

TD["event"]

以字符串形式包含事件:INSERTUPDATEDELETE或者TRUNCATE

TD["when"]

包含BEFOREAFTER或者INSTEAD OF之一。

TD["level"]

包含ROW或者STATEMENT

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"来表示你已经修改了新行。否则返回值会被忽略。