返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

40.2. 触发器函数

发布于 2019-09-30 03:09:48 字数 954 浏览 1100 评论 0 收藏 0

当一个函数用做触发器的时候,字典 TD 包含与触发器相关的数值。触发器行在 TD["new"] 和/或 TD["old"] 里面,具体情况取决于触发器事件。TD["event"] 中包含以字符串形式出现的事件(INSERT, UPDATE, DELETE, UNKNOWN)。TD["when"] 包含 BEFORE, AFTER, UNKNOWN 之一。TD["level"] 包含 ROW, STATEMENT, UNKNOWN 之一。TD["name"] 包含触发器名字,TD["table_name"] 包含触发器发生的表的名字,TD["table_schema"] 包含触发器发生的表的模式,TD["name"] 包含触发器名字,TD["relid"] 包含触发器发生的表的 OID 。如果 CREATE TRIGGER 包括函数参数,那么这些参数可以通过 TD["args"][0]TD["args"][(n-1)] 获得。

如果触发器的 TD["when"]BEFORE ,那么你可以从 Python 函数返回 None"OK" 以表示该行没有修改,返回 "SKIP" 以退出事件,或者 "MODIFY" 表示你已经修改了该行。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文