spring mysql 事物回滚吗_[spring,mysql] spring使用注解式事务声明(@Transactional)无法回滚 ....

@Transactional事务回滚

在service类前加上@Transactional,声明这个service所有方法需要事务管理。每一个业务方法开始时都会打开一个事务。

Spring默认情况下会对运行期例外(RunTimeException)进行事务回滚。这个例外是unchecked

如果遇到checked意外就不回滚。

如何改变默认规则:

1 让checked例外也回滚:在整个方法前加上 @Transactional(rollbackFor=Exception.class)

2 让unchecked例外不回滚: @Transactional(notRollbackFor=RunTimeException.class)

3 不需要事务管理的(只查询的)方法:@Transactional(propagation=Propagation.NOT_SUPPORTED)

注意: 如果异常在service层被try{}catch{}了,事务就不回滚了,如果想让事务回滚必须再往外抛try{}catch{throw Exception}。

针对Spring默认情况下RunTimeException @Transactional事务没有回滚,测试数据录入数据库中问题可按以下步骤进行检查:

1、检查下Spring配置没问题,代码也没问题;

2、检查Log4J日志输出,确实有进行事务回滚动作;

3、检查下MySQL后台日志输入,确实有进行“rollback”操作;

在网上搜了些资料,原来执行事务回滚的表默认有问题,MyISAM不支持事务!使用如下语句更改表类型为”InnoDB“:

altertableequ_upkeep_plan ENGINE=INNODB,也可以到mysql客户端修改

5f932c5cef7851e1ad2aabb96ca16bb2.png

参考博客:

(MySQL)Spring3+Mybatis3使用注解式事务声明(@Transactional)无法回滚

Spring @Transactional (一) 加强版

Spring transaction事务 roll back各种回滚

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值