在postgres 9.4中用触发器执行外部程序[英] execute external program with trigger in postgres 9.4

本文是小编为大家收集整理的关于在postgres 9.4中用触发器执行外部程序的处理方法,想解了在postgres 9.4中用触发器执行外部程序的问题怎么解决?在postgres 9.4中用触发器执行外部程序问题的解决办法?那么可以参考本文帮助大家快速定位并解决问题。

问题描述

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

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

提前致谢

推荐答案

声明:我和 Andreas Fritsch 在同一个项目上工作.

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

有一个"语言"扩展PL/sh Procedural Language Handler for PostgreSQL 由 Peter Eisentraut 编码这正是我们需要的.

你可以这样定义一个 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);

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

本文地址:https://www.itbaoku.cn/post/1764166.html