之前有个小测试发现事务不起作用,代理成功了,但事务就是不回滚。上网看到一片关于事务问题的总汇,才发现原来是我的数据库中表的类型不对,更改后事务问题就解决了,我也自己总结了一下
附:事务问题总汇地址: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,具体值是什么让事务不起作用就忘了,去掉这个限制域的属性和值就行了/