PROPAGATION_REQUIRES_NEW 和 PROPAGATION_NESTED两种传播机制的是容易混淆的。
1. 开启事务的多少,PROPAGATION_REQUIRES_NEW会开启很多事务,外部事务挂起,里面的事务独立执行,对性能的损耗较大。PROPAGATION_NESTED为父子事务,实际上是借助jdbc的savepoint实现的,属于同一个事物。
2. PROPAGATION_NESTED的回滚可以总结为,子事务回滚到savepoint,父事务可选择性回滚或者不不滚;父事务回滚子事务一定回滚。
PROPAGATION_NESTED如一下一樣
在oracle數據庫中
CREATE OR REPLACE PROCEDURE pro_test(fbuildareac IN VARCHAR2)
AS
BEGIN
update t_broker_house set fhousecondition=fid where fid='ed7c17ec-ca2a-4fe7-b7f7-f8111c102ade';
savepoint a;
update t_broker_house set fhousecondition=fid where fid='f456255f-1934-424f-81fb-6654829d4651';
rollback to a;
update t_broker_house set fhousecondition=fid where fid='bac6e97b-05f4-47db-b849-75d7d72d5ba6';
commit;
DBMS_OUTPUT.put_line (fbuildareac);
END pro_test;
begin
pro_test('123');
end;
第1個和第3個是可以修改成功的 第二個事务回滚