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

时间:2016-02-09 15:40:15

标签: linux postgresql postgresql-9.4

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

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

提前致谢

1 个答案:

答案 0 :(得分:4)

Disclamer:我和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语句

创建before-insert-trigger
CREATE TRIGGER tbefore BEFORE INSERT OR UPDATE OR DELETE ON ttest2
    FOR EACH ROW EXECUTE PROCEDURE TriggerTest(new);

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