sql >> Databáze >  >> RDS >> PostgreSQL

spustit externí program se spouštěčem v postgresu 9.4

Odmítnutí odpovědnosti: Pracuji s Andreasem Fritschem na stejném projektu.

Tento problém jsme vyřešili následujícím způsobem.

Existuje rozšíření "Language" PL/sh Procedural Language Handler pro PostgreSQL kódovaný Peterem Eisentrautem, který dělá přesně to, co potřebujeme.

Shell-script definujete takto:

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

Toto je příklad spouštěcí funkce s některými užitečnými proměnnými prostředí pro spouštěče:

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;

Spouštěč před vložením vytvoříte pomocí následujícího příkazu SQL

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

Doufám, že to pomůže každému, kdo hledá podobné řešení pro svůj problém.




  1. Jak dotazujete sloupec int na jakoukoli hodnotu?

  2. Stránkování pomocí OFFSET / FETCH:Lepší způsob

  3. php zobrazí víceúrovňovou nabídku stromových uzlů

  4. Java:Vrácení dat XMLType z StoredProcedure, použití ojdbc6.jar xdb6.jar xmlparserv2.jar pro interakci Java s PLSQL