Tuyên bố từ chối: Tôi làm việc với Andreas Fritsch trong cùng một dự án.
Chúng tôi đã giải quyết vấn đề này theo cách sau.
Có một "Ngôn ngữ" -extension PL / sh Trình xử lý ngôn ngữ thủ tục cho PostgreSQL được mã hóa bởi Peter Eisentraut, nó thực hiện chính xác những gì chúng ta cần.
Bạn xác định một shell-script như sau:
CREATE or REPLACE FUNCTION test(text) RETURNS text AS '
#!/bin/bash
echo Test: $1 is working
' LANGUAGE plsh;
Đây là một ví dụ về hàm kích hoạt với một số biến môi trường hữu ích cho trình kích hoạt:
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;
Bạn tạo trước-insert-trigger với SQL-Statement
sauCREATE TRIGGER tbefore BEFORE INSERT OR UPDATE OR DELETE ON ttest2
FOR EACH ROW EXECUTE PROCEDURE TriggerTest(new);
Tôi hy vọng điều này sẽ giúp bất kỳ ai khác đang tìm kiếm một giải pháp tương tự cho vấn đề của mình.