事务管理不起作用的几个原因

来源:互联网 发布:如何彻底删除手机数据 编辑:程序博客网 时间:2024/04/30 19:10


之前有个小测试发现事务不起作用,代理成功了,但事务就是不回滚。上网看到一片关于事务问题的总汇,才发现原来是我的数据库中表的类型不对,更改后事务问题就解决了,我也自己总结了一下

附:事务问题总汇地址:http://jinnianshilongnian.iteye.com/blog/1850432

1、数据库表类型错误

首先确定使用的数据库表的类型,如果表的类型为MyISAM,则sping里配置的事务肯定是不起作用的,应为这个类型的表是不支持事务滴;

所以使用InnoDB类型的表,因为这个类型的表才支持事务。更改表的类型:alert table xx type=InnoDB;

2、spring配置的扫描包错误

很多时候都会扫面所有的包,如果都使用注解的话,这是后最容易出现事务配置不起作用的问题

<context:annotation-config />

<context:component-scan base-package="com.will" />

当扫描所有包时,会把server层和dao层都扫描进去,因为这两个层是配置事务织入的层(一般事务都陪在server层),

这时候最容易出现事务配置不起作用的问题。

所以事务织入的那一层不要扫描进来,这时可以采用xml配置这个bean,如果controller层采用的是sping mvc,且采用注解的话,这时可以只扫描这个controller层,如

<context:annotation-config />

<context:component-scan base-package="com.will.controller" />

如果确实要扫描所要包,那么配置时只要把配置事务的那一层所使用的注解排除,如

<context:component-scan base-package="com.will">  

   <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/>  

</context:component-scan>  

通过exclude-filter 把所有 @Service注解的表现层控制器组件排除

3、所代理的方法是私有的

4、限制域

在配置数据原时有个参数属性是scope,具体值是什么让事务不起作用就忘了,去掉这个限制域的属性和值就行了/