zoukankan      html  css  js  c++  java
  • 关于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后,才支持对事务的处理

  • 相关阅读:
    fragment+viewpager+tablayou实现滑动切换页面
    XML转义字符
    java非覆盖写入文件及在输出文本中换行
    ObjectInputStream怎么判断是否读到末尾
    Linux下安装jdk(xxx.rpm,非xxx.tar.gz,请注意!)过程
    java接口(interface)
    IDEA快捷键(windows)
    maven插件maven-war-plugin
    maven插件maven-source-plugin
    maven插件maven-assembly-plugin
  • 原文地址:https://www.cnblogs.com/MrSong97/p/10456291.html
Copyright © 2011-2022 走看看