update restart

xsb發表於2007-12-28

Please note consistent read and current read when UPDATE statment start.

[@more@]

CREATE TABLE ud2_test(c1 NUMBER,c2 NUMBER,c3 NUMBER);
INSERT INTO ud2_test VALUES (1,1,1);
COMMIT;
CREATE OR REPLACE TRIGGER trg_ud2_test
BEFORE UPDATE ON ud2_test
FOR EACH ROW
BEGIN
dbms_output.put_line(:OLD.c1 || ',' || :OLD.c2 || ',' || :OLD.c3);
dbms_output.put_line(:NEW.c1 || ',' || :NEW.c2 || ',' || :NEW.c3);
END;

session1:

update ud2_test set c1=c1+1 where c2>0;
update ud2_test set c1=c1+1 where c2>0 ;
update ud2_test set c1=c1+1 where c2>0;

session2:

set serveroutput on
update ud2_test set c1=c1+10 where c2>0;
(session1 commit)
1,1,1
11,1,1
4,1,1
14,1,1
1 row updated
rollback;

etc:

update ud2_test set c3=c3+10 where c2>0;
(session1 commit)
4,1,1
4,1,11
5,1,1
5,1,11
1 row updated
rollback;

CREATE OR REPLACE TRIGGER trg_ud2_test
BEFORE UPDATE ON ud2_test
FOR EACH ROW
BEGIN
dbms_output.put_line( :OLD.c2 || ',' || :OLD.c3);
dbms_output.put_line( :NEW.c2 || ',' || :NEW.c3);
END;

update ud2_test set c3=c3+10 where c2>0;
(session1 commit)
4,1,1
4,1,11
1 row updated
rollback;

update ud2_test set c3=c3+10 where c1>0;
(session1 commit)
4,1,1
4,1,11
4,1,1
4,1,11
1 row updated
rollback;

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12402/viewspace-995965/,如需轉載,請註明出處,否則將追究法律責任。

相關文章