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

来源:互联网 发布:网络舆情分析师待遇 编辑:程序博客网 时间:2024/06/05 03:19

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

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

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

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

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

alter table table_name engine=innodb;


原创粉丝点击