关于SSM项目注解事务不回滚的问题

<!--扫描service包(包含子包)下所有使用注解的类型-->
<context:component-scan base-package="com.song.ssm.service"/>

<!--配置事务管理器(mybatis采用的是JDBC的事务管理器)-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  <property name="dataSource" ref="dataSource"></property>
</bean>

<!--配置基于注解的声明式事务,默认使用注解来管理事务行为-->
<tx:annotation-driven transaction-manager="transactionManager"/>

xml配置如上

1.添加声明式事务配置

然后在service.impl层测试抛出异常,回滚操作的数据,在方法上添加注解

@Transactional(rollbackFor=Exception.class)//作用是当前方法抛出rollbackFor指定的异常类时则回滚

 

2.发现抛出异常后,操作的数据未回滚,开始查找原因

尝试手动回滚数据

Venue venue = new Venue();
venue.setShowflag(1);// 测试修改数据
try {
    updateByPrimaryKey(venue);
    String string = "abc";
    Integer.valueOf(string);
} catch (Exception e) {
  TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); //手动开启事务回滚
  throw new RuntimeException();  
}

发现依旧未回滚操作数据

 

3.检查数据库表引擎

发现数据表引擎是MyISAM,查找了一下引擎之间的关系,如下

然后得知我们要求处理事务则必须使用INNODB或者BERKLEYDB,然后用sql语句将表修改为INNODB,ALTER TABLE `Venue` ENGINE = `InnoDB

修改后我再次尝试抛出异常回滚代码,回滚机制生效了,被操作的数据没有持久化到数据库中

 

4.总结

由于数据库引擎的限制,MyISAM引擎没有对事务处理的能力,将表的引擎切换到INNODB后,才支持对事务的处理

 

转载于:https://www.cnblogs.com/MrSong97/p/10456291.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值