MyBatis 不支持Spring事务管理的问题总结

之前有个同事问我, 关于MyBatis不支持Spring事务管理的问题:
对spring,mybatis进行整合时发现事务不能进行回滚处理,上网查了很多资料依旧还没解释,很多都是说要抛出一个runtimeException才能回滚的,但尝试过多种还不能。

这里我给出我的解决方法和答案,我自己尝试成功
我用的是 SSM3的框架 Spring MVC 3.1 + Spring 3.1 + Mybatis3.1 + Oracle数据库

第一种情况
Spring MVC 和 Spring 整合的时候,SpringMVC的springmvc.xml文件中 配置扫描包,不要包含 service的注解,Spring的applicationContext.xml文件中 配置扫描包时,不要包含controller的注解,如下所示:
SpringMVC的xml配置:

  

Spring MVC启动时的配置文件,包含组件扫描、url映射以及设置freemarker参数,让spring不扫描带有@Service注解的类。为什么要这样设置?因为springmvc.xml与applicationContext.xml不是同时加载,如果不进行这样的设置,那么,spring就会将所有带@Service注解的类都扫描到容器中,等到加载applicationContext.xml的时候,会因为容器已经存在Service类,使得cglib将不对Service进行代理,直接导致的结果就是在applicationContext 中的事务配置不起作用,发生异常时,无法对数据进行回滚。以上就是原因所在。
同样的在Spring的xml配置如下:

           

 

扫描包路径,不扫描带有@Controller注解的类。因为这些类已经随容器启动时,在springmvc.xml中扫描过一遍了。
完成以上工作,我的Spring就支持事务回滚了。OK

第二种情况:使用了MySQL数据库,如果用mysql数据库,数据库表你如果是自动建表,那么就需要把建表的Engine设置为InnoDB格式,自动建表的格式为:MyISAM,这中格式的是不支持事务管理的。 

第三种情况:在测试代码中,一定要在catch块中抛出 异常 ,以便Spring事务能发现异常。

注意以上几点就OK了。

转载于:https://my.oschina.net/vshcxl/blog/886295

你可能感兴趣的:(MyBatis 不支持Spring事务管理的问题总结)