最近项目突然出了点问题,然后发现用Service层下面的一个类的一个方法里的事务居然没有回滚。然后自己写了一个测试方法经过了N次测试都是不回滚。以下是测试方法的一部分:

@Transactional(propagation =Propagation.REQUIRED,rollbackFor=RuntimeException.class)

public String getOnLineNum(String securecrt){
History his=new History();
his.setItem("123"); //此处特意设置一个超出字段长度使其出错
Ludan lu=new Ludan();
lu.setRoomName("33333333333333333"); historyDao.save(his);
ludanDao.save(lu); return "123";
}

以上代码经过许多次的测试都是会把history表存入记录,但是ludan报错存入不了,这样相当于事务并没有回滚。

如下是Spring的部分配置:

<!-- spring 事务管理 start-->
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref local="sessionFactory" />
</property>
</bean> <!-- 声明使用注解式事务 -->
<tx:annotation-driven transaction-manager="transactionManager"/>

一。 如上就是问题,然后经过大范围的查阅以及搜索,最后总结了几点Spring事务不回滚的原因:

1.你自己捕获异常了,没有抛出去让Spring知道。

2.没有正确配置Spring中的事务。

3.Service层次问题,即一些逻辑问题。

4.MySQL不支持事务。

二。解决办法

这里重点讲解一下上线的第四种原因的解决办法,这也是本人项目中遇到的问题。即MYSQL默认的数据库模式是MyISAM,而这个模式是不支持事务的,并且在安装mysql的时候默认的数据库模式就是MyISAM。在mysql里输入:show engines;就会看到如下的画面:

可以看到只有InnoDB才支持事务。因此要实现mysql的事务必须先把mysql数据库模式转换成InnoDB。

具体方法如下:

1.打开根目录下得my.ini文件,在[mysqld]下加入:

default-storage-engine=INNODB

如果有skip-innodb,那就把这行注掉即可。

2.重启mysql服务

3.再次进入mysql,输入:show engines;就可以看到默认的数据库模式已经是INNODB了;

4.原来存在的表则需要删除以后再重新建一个就是INNODB的了,如果不想删除,那就进入mysql,更新一下表引擎就可以了

执行:alter table 表名 ENGINE=InnoDB;

然后在执行:show table status from 数据库名 where name='表名';就可以查看状态了

5.再次测试上面的代码就发现事务回滚了。

三。总结

对于这个自己遇到的问题可能是大部分人都遇到过的问题吧,也算是自己的经验不足造成的,因此记录下来方便一些像我一样走在程序的路上的朋友们,希望能对大家有一些帮助,也同时做一个自己的工作记录吧,以后也可以回来再次审查。

Spring+hibernate+mysql事物不回滚的原因以及处理的更多相关文章

  1. MySql事务无法回滚的原因

    使用MySQL时.假设发现事务无法回滚,但Hibernate.Spring.JDBC等配置又没有明显问题时.不要苦恼,先看看MySQL创建的表有没有问题.即表的类型. InnoDB和MyISAM是在使 ...

  2. spring 事物不回滚

    使用spring控制事物,为什么有些情况事物,事物不回滚呢?? 默认spring事务只在发生未被捕获的 RuntimeException时才回滚.   spring aop  异常捕获原理: 被拦截的 ...

  3. spring事物不回滚的问题

    学习spring分布式事务的时候,自己整了个demo,写test测试的时候发先事物没有回滚.此问题和分布式事务没关系.1.在service层引入@Transaction注解 使用 throw new ...

  4. 哪些异常是RuntimeException?Sql异常属于RuntimeException吗?Spring下SQL异常事务回滚

    一,为什么框架中根本没有对Exception的一般子类进行回滚配置,异常发生时,事务都进行了回滚 ,说好的只会对RuntimeException(Unchecked 非受检异常)回滚呢? 此时,我们就 ...

  5. 第二百八十六节,MySQL数据库-MySQL事务操作(回滚)

    MySQL数据库-MySQL事务操作(回滚) 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 举例:有这样一张表 从表里可以看出张 ...

  6. 【Java EE 学习 53】【Spring学习第五天】【Spring整合Hibernate】【Spring整合Hibernate、Struts2】【问题:整合hibernate之后事务不能回滚】

    一.Spring整合Hibernate 1.如果一个DAO 类继承了HibernateDaoSupport,只需要在spring配置文件中注入SessionFactory就可以了:如果一个DAO类没有 ...

  7. Spring事物不回滚

    今天发现个自己的bug,仔细排查后,发现根本原因我在service方法中抛出的异常被控制层的方法捕获了,所以后台页面也只是出现个错误提示,而数据却没有回滚. 解决方式:对自己抛出的异常使用try ca ...

  8. SpringBoot使用Junit测试 防止事物自动回滚

           问题:我在测试类中的save方法测试成功通过,但数据库没有插入数据 测试方法如下: @Test @Transactional // @Rollback(false) public voi ...

  9. spring@Transactional注解事务不回滚不起作用无效的问题处理

    这几天在项目里面发现我使用@Transactional注解事务之后,抛了异常居然不回滚.后来终于找到了原因. 如果你也出现了这种情况,可以从下面开始排查. 一.特性先来了解一下@Transaction ...

随机推荐

  1. CUDA ---- Kernel性能调节

    Exposing Parallelism 这部分主要介绍并行分析,涉及掌握nvprof的几个metric参数,具体的这些调节为什么会影响性能会在后续博文解释. 代码准备 下面是我们的kernel函数s ...

  2. 配置javaBean

    bean基本配置: <bean id="exampleBean" class="examples.ExampleBean"></bean> ...

  3. php property_exists

    property_exists("Device",$prop))判断Device 类中是否存在 $prop 这个属性该函数用来判断一个类中是否存在某个属性. 这里分析了php面向对 ...

  4. pdo 操作

    $dbhost = 'localhost';$dbname = 'dcim';$dbuser = 'dcim';$dbpass = 'dcim'; $locale = "en_US" ...

  5. 20155220 2016-2017-2 《Java程序设计》第九周学习总结

    20155220 2016-2017-2<Java程序设计>第九周学习总结 教材学习内容总结 JDBC(Java DataBase Connectivity)即java数据库连接,是一种用 ...

  6. CTF之猪圈密码

    猪圈密码又称济会密码,朱高密码,是一种简单的替代密码,所以安全性很低

  7. hdu2069-2071

    hdu2069 选取硬币组成定值,暴力 #include<stdio.h> ]={,,,,,}; int main(){ int n; while(scanf("%d" ...

  8. 最小生成树--prim+优先队列优化模板

    prim+优先队列模板: #include<stdio.h> //大概要这些头文件 #include<string.h> #include<queue> #incl ...

  9. layer关闭弹出层总结

    //关闭方法1 layer提供了5种层类型.可传入的值有:0(信息框,默认)1(页面层)2(iframe层)3(加载层)4(tips层). 若你采用layer.open({type: 1})方式调用, ...

  10. Struts2重新学习之自定义拦截器(判断用户是否是登录状态)

    拦截器 一:1:概念:Interceptor拦截器类似于我们学习过的过滤器,是可以再action执行前后执行的代码.是web开发时,常用的技术.比如,权限控制,日志记录. 2:多个拦截器Interce ...