Stoyan Genov wrote:
> ...
> I would like also to build a rule which works on the "reverse DELETE"
> condition, and disallows deleting t1 records if there is a "child" in t2
> present.
> Does somebody have any ideas? Thanks in advance.
You can use ap pair of triggers to keep the referential integrity.
example:
create table master ( mid int4 not null, name text);
create unique index master_idx on master(mid);
/* foreign key mid in detail references the primary key mid in master */
create table detail ( did int4 not null, name text, mid int4 not null);
create unique index detail_idx on detail(did);
/* allow PL/pgSQL procedures */
create function plpgsql_call_handler () returns opaque as '/usr/local/pgsql/lib/plpgsql.so' language 'C';
create trusted procedural language 'plpgsql' handler plpgsql_call_handler lancompiler 'PL/pgSQL';
/* handle delete and update in master */
create function del_master_fun () returns opaque as ' declare id int4; begin select did into id from detail d
where d.mid = old.mid; if found then raise exception ''cannot %'', tg_op; end if; if tg_op = ''DELETE''
then return old; else return new; end if; end;
' language 'plpgsql';
create trigger del_master_trg before delete or update on master for each row execute procedure del_master_fun();
/* handle insert and update in detail */
create function ins_detail_fun () returns opaque as ' declare id int4; begin select mid into id from master m
where m.mid = new.mid; if not found then raise exception ''cannot %'', tg_op; end if; return new; end;
' language 'plpgsql';
create trigger ins_detail_trg before insert or update on detail for each row execute procedure ins_detail_fun();
I hope this will help you.
Gerhard