Thursday, August 1, 2013

new and old trigger code

:new and :old are pseudo-records that let you access the new and old values of particular columns. If I have a table
CREATE TABLE foo (
  foo_id NUMBER PRIMARY KEY,
  bar    VARCHAR2(10),
  baz    VARCHAR2(10)
);
and I insert a row
INSERT INTO foo( foo_id, bar, baz ) 
  VALUES( 1, 'Bar 1', 'Baz 1' );
then in a row-level before insert trigger
:new.foo_id will be 1
:new.bar will be 'Bar 1'
:new.baz will be 'Baz 1'
while
:old.foo_id will be NULL
:old.bar will be NULL
:old.baz will be NULL
If you then update that row
UPDATE foo
   SET baz = 'Baz 2'
 WHERE foo_id = 1
then in a before update row-level trigger
:new.foo_id will be 1
:new.bar will be 'Bar 1'
:new.baz will be 'Baz 2'
while
:old.foo_id will be 1
:old.bar will be 'Bar 1'
:old.baz will be 'Baz 1'
If I then delete the row
DELETE FROM foo
 WHERE foo_id = 1
then in a before delete row-level trigger,
:new.foo_id will be NULL
:new.bar will be NULL
:new.baz will be NULL
while
:old.foo_id will be 1
:old.bar will be 'Bar 1'
:old.baz will be 'Baz 2'
http://stackoverflow.com/questions/10639331/new-and-old-trigger-code

No comments:

Post a Comment