最近写代码,在service层代码里普遍使用类事务,会导致一些锁等待超时问题,就这个问题做一次总结,事务的范围尽可能的缩小,最好思考一下你这个业务场景是否真正的需要用到事务,像一些查询,可想而知是没必要的,所以类上不应该事务注解,必须细化到方法上,像一些关键性的数据修改,比如金钱操作之类的方法,这是我认为他使用场景,而这里比较注意的一点是,有时候我们使用循环操作数据,这时候,如果你使用方法性事务长时间结束不了方法,就会造成我上面所说的问题,事务会一直处于开启状态,导致无法释放锁,在别的事务开启时候,去操作你锁住的数据会造成锁超时异常。
解决思路就是:将锁的操作尽快结束,每次循环开启一次事务,有两种方案:
1.是使用编程式事务。
2.使用方法将每一个单元操作放到一个方法中,每次循环调用该方法,但是service层调用另一个方法会遇到另一个方法的事务不生效,只能另外建一个service层来进行这个操作。
注:我只代表我的个人看法,如果有异议可以提出来,有错误我会及时纠正。