I have a question to creating a rule:
CREATE RULE dbmail_mailboxes_autocreate AS ON INSERT TO dbmail_users DO
ALSO insert into dbmail_mailboxes (owner_idnr,name) values
(NEW.user_idnr,'INBOX'), (NEW.user_idnr,'Gesendete Objekte'),
(NEW.user_idnr,'Entwürfe'), (NEW.user_idnr,'Junk'),
(NEW.user_idnr,'Papierkorb');
ERROR: VALUES must not contain OLD or NEW references
TIP: Use SELECT ... UNION ALL ... instead.
But in http://www.postgresql.org/docs/8.3/interactive/rules-update.html
the examples also use NEW in the values. Or can I only use a rule within
the same table?
If I need to use a TRIGGER: I tried with creating a function, but I
don't know how to pass the current user_idnr to that function from the
trigger. I managed to create the function:
CREATE FUNCTION dbmail_mailboxes_autocreate_function(user_idnr bigint)
returns integer AS $$ BEGIN insert into dbmail_mailboxes
(owner_idnr,name) values (user_idnr,'INBOX'), (user_idnr,'Gesendete
Objekte'), (user_idnr,'Entwürfe'), (user_idnr,'Junk'),
(user_idnr,'Papierkorb'); END; $$ LANGUAGE plpgSQL;
But I don't know how to do the trigger. Can someone help me?
mfg zmi
--
// Michael Monnerie, Ing.BSc ----- http://it-management.at
// Tel: 0660 / 415 65 31 .network.your.ideas.
// PGP Key: "curl -s http://zmi.at/zmi.asc | gpg --import"
// Fingerprint: AC19 F9D5 36ED CD8A EF38 500E CE14 91F7 1C12 09B4
// Keyserver: wwwkeys.eu.pgp.net Key-ID: 1C1209B4