在 postgres 9.4 中使用触发器执行外部程序

Posted

技术标签:

【中文标题】在 postgres 9.4 中使用触发器执行外部程序【英文标题】:execute external program with trigger in postgres 9.4 【发布时间】:2016-02-09 15:40:15 【问题描述】:

我正在寻找一种在更新或使用触发器插入后执行系统命令的方法。我希望 postgres 可以做到这一点。 有可能吗?

CREATE TRIGGER check_update
AFTER UPDATE ON allowed_member_type
FOR EACH ROW
EXECUTE PROCEDURE check_account_update();

提前致谢

【问题讨论】:

Call command-line function in Perl and get output as String的可能重复 这不是重复的。在 Postgres 9.4 上它不起作用。 【参考方案1】:

免责声明:我与 Andreas Fritsch 在同一个项目上工作。

我们通过以下方式解决了这个问题。

有一个由 Peter Eisentraut 编码的“语言”扩展 PL/sh Procedural Language Handler for PostgreSQL,它完全可以满足我们的需要。

你可以这样定义一个 shell 脚本:

CREATE or REPLACE FUNCTION test(text) RETURNS text AS '
#!/bin/bash
echo Test: $1 is working
' LANGUAGE plsh;

这是一个触发器函数示例,其中包含一些有用的触发器环境变量:

CREATE or REPLACE FUNCTION TriggerTest() RETURNS trigger AS $$
#!/bin/bash
#mkdir /has/triggertest/$PLSH_TG_NAME
cd /has/triggertest
touch PLSH_TG_NAME-$PLSH_TG_NAME
touch PLSH_TG_WHEN-$PLSH_TG_WHEN
touch PLSH_TG_LEVEL-$PLSH_TG_LEVEL
touch PLSH_TG_OP-$PLSH_TG_OP
touch PLSH_TG_TABLE_NAME-$PLSH_TG_TABLE_NAME
touch PLSH_TG_TABLE_SCHEMA-$PLSH_TG_TABLE_SCHEMA
touch new-$new.x
#touch "arg-0-'$0'"
touch "arg-1-'$1'"
touch "arg-2-'$2'"
touch "arg-3-'$3'"
touch "arg-4-'$4'"

for arg do
    touch "Arg is '$arg'"
done

exit 0
$$ LANGUAGE plsh;

您使用以下 SQL 语句创建插入前触发器

CREATE TRIGGER tbefore BEFORE INSERT OR UPDATE OR DELETE ON ttest2
    FOR EACH ROW EXECUTE PROCEDURE TriggerTest(new);

我希望这对正在为他的问题寻找类似解决方案的其他人有所帮助。

【讨论】:

还有:shellscript 的exit 1 会导致触发器失败吗? 是的,插入失败并显示“错误:脚本以状态 1 退出”,并且 before-insert-trigger 取消了插入。我没有测试任何其他类型的触发器,但我认为其他触发器是相同的。 我尝试了这种方法,但 $new 在触发器中不可用 如何在 heroku postgres 上运行它?

以上是关于在 postgres 9.4 中使用触发器执行外部程序的主要内容,如果未能解决你的问题,请参考以下文章

在较旧的 Postgres (9.4) 上使用 Django 3+

在从 Postgres 9.4 到 Greenplum 的数据迁移过程中,我应该如何处理我的 UNIQUE 约束

使用 postgres 9.4 将 JSON 元素附加到数组

在 Postgres 9.4 中查找 JSON 数组中的最后一项

在 Postgres 9.4+ 中索引 JSONB 嵌入式 Ecto2 模型

如何在 postgres 9.4 中删除复制槽