spring事务回滚的部分说明及出现问题解决

未作任何配置的情况下,spring只对运行期异常,即RuntimeException进行回滚;

通过在方法前加上@Transactional(rollbackFor=Exception.class)的注解,可以让非运行期异常也可以进行事务回滚;

而当你的spring项目对运行期异常无法回滚,对进行注解之后的非运行期异常也无法进行事务回滚时,那就厉害啦,恭喜你中了大奖。

其原因为数据库的表,不支持事务!如果mysql不支持存储引擎,它将以MyISAM表创建表,这是非事务性表,因此你无论怎么折腾他都不会进行事务回滚。 一般修改成InnoDB就可以解决该问题了。

如果你不相信是这个引起的问题,或者说你想进一步确认,那么你可以通过在MySQL中输入下述代码来查看表所使用的引擎:
mysql> show create table 表名;
当你发现确实是引擎的问题时,可以通过在MySQL中输入下述代码来修改表所使用的引擎:

alter table table_name engine=innodb;


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值