Postgresql 更新触发器不接受 When / OF 条件

发布于 2024-11-07 03:33:21 字数 689 浏览 1 评论 0原文

我正在尝试编写一个触发器,但出现语法错误:

CREATE TRIGGER archive_domain_trig
  AFTER UPDATE OF is_rejected ON pending_domains
  FOR EACH ROW 
  WHEN (new.is_rejected is True)
  EXECUTE PROCEDURE archive_domain_fun();

错误:“OF”处或附近的语法错误

不仅如此,而且它还在“when”条件上给出错误,例如

CREATE TRIGGER archive_domain_trig
  AFTER UPDATE ON pending_domains
  FOR EACH ROW 
  WHEN (new.is_rejected is True)
  EXECUTE PROCEDURE archive_domain_fun();

给出:

错误:“WHEN”处或附近的语法错误。

select version();
"EnterpriseDB 8.3.0.116 on x86_64-unknown-linux-gnu, compiled by GCC gcc (GCC) 4.1.0"

这几乎与 postgres 的例子类似,谁能告诉我我在这里做错了什么?

I am trying to write a trigger but getting syntax error:

CREATE TRIGGER archive_domain_trig
  AFTER UPDATE OF is_rejected ON pending_domains
  FOR EACH ROW 
  WHEN (new.is_rejected is True)
  EXECUTE PROCEDURE archive_domain_fun();

ERROR: syntax error at or near "OF"

not only this but it is giving error on "when" condition also e.g.

CREATE TRIGGER archive_domain_trig
  AFTER UPDATE ON pending_domains
  FOR EACH ROW 
  WHEN (new.is_rejected is True)
  EXECUTE PROCEDURE archive_domain_fun();

gives:

ERROR: syntax error at or near "WHEN".

select version();
"EnterpriseDB 8.3.0.116 on x86_64-unknown-linux-gnu, compiled by GCC gcc (GCC) 4.1.0"

This is almost similar to postgres example, can anyone tell me what am I doing wrong here?

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

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

饮惑 2024-11-14 03:33:21

我猜测 EnterpriseDB 8.3 是 PostgreSQL 8.3 的 EnterpriseDB 版本。条件触发器(即 WHEN 选项)是 PostgreSQL 9.0 中的新功能。比较 8.39.0

I'd guess that EnterpriseDB 8.3 is the EnterpriseDB version of PostgreSQL 8.3. Conditional triggers (i.e. the WHEN option) are a new feature in PostgreSQL 9.0. Compare the CREATE TRIGGER documentation for 8.3 and 9.0.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文