spring事务的注意事项有哪些,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
事务一般是指数据库事务,是指作为一个程序执行单元执行的一系列操作,要么完全执行,要么完全不执行。事务就是判断以结果为导向的标准。
spring的特性(ACID)
(1).原子性(atomicity)
原子性就是一个不可分割的工作单元。简单的说,就是指事务包含的所有操作要么全部成功,要么全部失败回滚。因此事务的操作如果成功就必须要完全应用到数据库,如果失败则不能对数据库有任何影响。
(2).一致性(consistency)
一致性就是事务必须是使一个一致性状态变成另一个状态,也就是说一个书屋执行之前和执行之后都必须处于一致性状态。那转账来说,假设用户A和用户B两者的钱加起来一共是5000.那么不管A和B之间如何转账,转多少次,事务结束后两者的钱加起来还是5000。
(3).隔离性(isolation)
隔离性就是一个事务的执行不能被另一个事务干扰。当多个用户并发访问数据库操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,并发事务之间要相互隔离。
(4).持久性(durability)
持久性是指一个事务一旦被提交了,那么对数据库数据的改变就是永久的。即使是在数据系统遇到故障的情况下也不会丢失提交事务的操作。
spring的隔离级别
*脏读:一个事务读到了另一个事务未提交的数据
*不可重复读:一个事务读到另一个事务已经提交(update)的数据导致多次查询结果不一致
*虚幻读:一个事务读到了另一个事务已经提交(insert)的数据导致多次查询结果不一致。
对于sqlserver和oracle的默认隔离级别是RC,mysql的默认隔离级别是RR。
spring的注意事项
1.出现Exception是无法回滚的,只有抛出RuntimeException和Error异常时才能回滚。2.在事务代码中捕获了异常,是无法进行回滚的。
3.如果是使用的spring+mvc模式。并且spring和mvc都扫描了service层(事务处理层),事务不生效。因为spring会有限加载mvc的配置文件,而事务的配置基本上都是在spring中,因为spring的子容器先于父容器启动,造成在controller中注入service时还没有加载事务。
4.mysql的myISAM引擎,是不支持事务的,需要设置为innoDB模式。
5.事务的开启必须放到listener里面加载,如果放到dispatchServlet的配置里面,事务不生效。
6.如果在接口中使用@Transactional,只有JDK动态代理才能生效,CGLIB动态代理是不生效的,因为注解是不能继承的。
关于spring事务的注意事项有哪些问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。