sql >> Database teknologi >  >> RDS >> PostgreSQL

udfør eksternt program med trigger i postgres 9.4

Ansvarsfraskrivelse: Jeg arbejder sammen med Andreas Fritsch på det samme projekt.

Vi har løst dette problem på følgende måde.

Der er en "Language"-udvidelse PL/sh Procedural Language Handler for PostgreSQL kodet af Peter Eisentraut, som gør præcis, hvad vi har brug for.

Du definerer et shell-script som dette:

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

Dette er et eksempel på en trigger-funktion med nogle nyttige miljøvariabler for triggere:

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 opretter en før-indsæt-trigger med følgende SQL-sætning

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

Jeg håber, at dette hjælper enhver anden, der leder efter en lignende løsning på sit problem.




  1. Gruppér efter for at skabe en lodret sammensmeltning

  2. localhost vs. 127.0.0.1 i mysql_connect()

  3. Primær nøgle-id når grænsen for bigint-datatype

  4. Er det muligt at bruge SqlGeography med Linq til Sql?