diff options
author | Peter Eisentraut <peter_e@gmx.net> | 2011-02-26 16:53:11 +0200 |
---|---|---|
committer | Peter Eisentraut <peter_e@gmx.net> | 2011-02-26 16:53:11 +0200 |
commit | bc411f25c14f65b459de5dbc96ac79e7741ef9ee (patch) | |
tree | 5738e51994019a342501a111aad64fe369664405 /src/pl/plpython/sql/plpython_trigger.sql | |
parent | 772dcfe7c0b3c678c8aef11de2bf8a52150a56f1 (diff) | |
download | postgresql-bc411f25c14f65b459de5dbc96ac79e7741ef9ee.tar.gz postgresql-bc411f25c14f65b459de5dbc96ac79e7741ef9ee.zip |
Table function support for PL/Python
This allows functions with multiple OUT parameters returning both one
or multiple records (RECORD or SETOF RECORD).
Jan UrbaĆski, reviewed by Hitoshi Harada
Diffstat (limited to 'src/pl/plpython/sql/plpython_trigger.sql')
-rw-r--r-- | src/pl/plpython/sql/plpython_trigger.sql | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/pl/plpython/sql/plpython_trigger.sql b/src/pl/plpython/sql/plpython_trigger.sql index 4994d8fe7bb..2afdf511275 100644 --- a/src/pl/plpython/sql/plpython_trigger.sql +++ b/src/pl/plpython/sql/plpython_trigger.sql @@ -326,3 +326,23 @@ INSERT INTO pb VALUES ('a', '2010-10-09 21:57:33.930486'); SELECT * FROM pb; UPDATE pb SET a = 'b'; SELECT * FROM pb; + + +-- triggers for tables with composite types + +CREATE TABLE comp1 (i integer, j boolean); +CREATE TYPE comp2 AS (k integer, l boolean); + +CREATE TABLE composite_trigger_test (f1 comp1, f2 comp2); + +CREATE FUNCTION composite_trigger_f() RETURNS trigger AS $$ + TD['new']['f1'] = (3, False) + TD['new']['f2'] = {'k': 7, 'l': 'yes', 'ignored': 10} + return 'MODIFY' +$$ LANGUAGE plpythonu; + +CREATE TRIGGER composite_trigger BEFORE INSERT ON composite_trigger_test + FOR EACH ROW EXECUTE PROCEDURE composite_trigger_f(); + +INSERT INTO composite_trigger_test VALUES (NULL, NULL); +SELECT * FROM composite_trigger_test; |