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個是可以修改成功的 第二個事务回滚
本文深入探讨了PROPAGATION_REQUIRES_NEW和PROPAGATION_NESTED两种事务传播机制的区别,通过实例展示了在Oracle数据库中的应用,包括如何使用savepoint进行事务回滚,以及它们对性能的影响。
1205

被折叠的 条评论
为什么被折叠?



