当函数被用作触发器时,字典TD包含与触发器相关的值:
TD["event"]以字符串形式包含事件:INSERT、UPDATE、DELETE或者TRUNCATE。
TD["when"]包含BEFORE、AFTER或者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"]是BEFORE或INSTEAD OF,且TD["level"]是ROW,那么可以从 Python 函数返回None或"OK"来表示该行未被修改,返回"SKIP"来中止该事件;如果TD["event"]是INSERT或UPDATE,还可以返回"MODIFY"来表示你已经修改了新行。否则返回值会被忽略。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。