前几天我发了这篇文章<我来出个题:这个事务会不会回滚?>得到了很多不错的反馈,也有不少读者通过微信.群或者邮件的方式,给了我一些关于test4的回复.其中还有直接发给我测试案例,来证明我的答案是错的.今天,我们就来一起看看test4这个争议很大的问题.如果您是刚打开这篇文章,不了解我们在讨论啥,那可以先点击查看之前的这篇<我来出个题:这个事务会不会回滚?>.通过这两篇文章的解析,相信你会对Spring Data JPA下的事务执行机制有质的飞跃. 为什么没回滚 先来说说,那些写了代
存储过程中的 SET XACT_ABORT ON 和事务 在存储过程中写SET XACT_ABORT ON 有什么用? SET XACT_ABORT ON是设置事务回滚的! 当为ON时,如果你存储中的某个地方出了问题,整个事务中的语句都会回滚 为OFF时,只回滚错误的地方 ----------------------------------------------------------------------------------------------- 第一种情况:每次成功执行一条语句就
SET XACT_ABORT on BEGIN TRAN INSERT INTO [PDA_Action] VALUES ('採购入库1') INSERT INTO [PDA_Action] VALUES ('採购入库2') SELECT 1/0 /* 除数为0错误 */ INSERT INTO [PDA_Action] VALUES ('採购入库3') INSERT INTO [PDA_Action] VALUES ('採购入库4') COMMIT TRAN 对于有select