springBoot+JPA+Mysql项目中的事物管理,发生异常未回滚的问题

    今天在项目中调试代码的时候,方法中报错,当去数据库中查看该方法操作的那条数据记录时,发现数据已经被修改了。但是该方法整体是处在@Transactional事物管理之下的,也就是说,发生异常时,事物没有回滚。

    经过查找原因,发现是Mysql表类型问题。Mysql表类型分为InnoDBMyISAM,二者有本质上的区别。具体区别请链接到http://www.cnblogs.com/xiohao/p/3633418.html

    确实,我通过JPA自动创建出来的表,是MyISAM型的,修改表类型,问题解决。但是根本原因在于JPA自动创建表时,表类型为什么会是MyISAM非事物型。

    在我的项目里,yml配置文件中,设置了hibernate方言为MySQL5Dialect,后来将配置改为 MySQL5InnoDBDialect,生成的表类型就变成了InnoDB型。数据库版本:Mysql5.7 , hibernate :hibernate-core-5.2.14


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值