sql >> Databasteknik >  >> RDS >> PostgreSQL

exekvera externt program med trigger i postgres 9.4

Ansvarsfriskrivning: Jag arbetar med Andreas Fritsch i samma projekt.

Vi har löst detta problem på följande sätt.

Det finns en "Language"-tillägg PL/sh Procedural Language Handler för PostgreSQL kodad av Peter Eisentraut som gör precis vad vi behöver.

Du definierar ett skal-skript så här:

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

Detta är ett exempel på en triggerfunktion med några användbara miljövariabler för triggers:

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;

Du skapar en före-insert-trigger med följande SQL-sats

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

Jag hoppas att detta hjälper någon annan som letar efter en liknande lösning för sitt problem.




  1. Oracle/SQL:Varför frågar SELECT * FROM-poster WHERE rownum>=5 AND rownum <=10 - returnerar noll rader

  2. Oracle Ta bort rader som matchar flera värden

  3. Upptäcker låsta bord (låsta av LOCK TABLE)

  4. PDO-fel:Ogiltigt parameternummer:parametern har inte definierats