【发布时间】:2011-11-20 04:17:27
【问题描述】:
我在尝试自主事务时遇到了一个有趣的情况。考虑以下情况(请注意,它不打算这样写:只是概念证明):
create table t
(
id int primary key,
changed date
)
/
create or replace trigger t_trig
before insert or update
on t
for each row
declare
PRAGMA AUTONOMOUS_TRANSACTION;
begin
:new.changed := sysdate;
commit;
end;
/
insert into t(id, changed) values (1, sysdate);
insert into t(id, changed) values (2, sysdate);
截至当前时间的更改日期:
SQL> select * from t;
ID CHANGED
--------- -----------------
1 19.09.11 15:29:44
2 19.09.11 15:32:35
让我们休息 5 秒,然后执行以下操作:
update t set id = 2 where id = 1;
显然它会因违反约束而失败,但它也不会更改changed 属性:
SQL> select * from t;
ID CHANGED
--------- -----------------
1 19.09.11 15:29:44
2 19.09.11 15:32:35
我的问题是:为什么会这样?我确定我误解了一些基本概念,但我无法理解。
提前感谢您的帮助。
【问题讨论】:
标签: oracle transactions triggers constraints