| From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> | 
|---|---|
| To: | Jeff Post <POSTJL(at)milwaukee(dot)k12(dot)wi(dot)us> | 
| Cc: | pgsql-sql(at)postgresql(dot)org | 
| Subject: | Re: Preventing Deletions with triggers | 
| Date: | 2004-05-21 15:28:52 | 
| Message-ID: | 4042.1085153332@sss.pgh.pa.us | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-sql | 
Jeff Post <POSTJL(at)milwaukee(dot)k12(dot)wi(dot)us> writes:
> CREATE or replace FUNCTION person_fake_delete() RETURNS TRIGGER AS '
>      BEGIN
>          OLD.status := 1; -- This does the fake deletion
>          RETURN NULL;  -- I thought this would prevent the delete from 
> actually happening.
>      END;
> ' LANGUAGE 'plpgsql';
> create trigger person_fake_delete
> before delete on person
> for each row EXECUTE PROCEDURE
> person_fake_delete();
> This however does not work.  the tupple is still deleted from the 
> table.    Any Ideas?
It works for me, in the sense that returning NULL prevents the
deletion.  However that assignment to OLD is a no-op: you can't change
the tuple that way.  You'd have to do something like
UPDATE person SET status = 1 WHERE key = OLD.key;
("key" being whatever your primary key for the table is)
regards, tom lane
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Alexander M. Pravking | 2004-05-22 17:54:19 | Memory usage on subselect | 
| Previous Message | Tom Lane | 2004-05-21 15:05:28 | Re: Problem with JOINS |