spring aop 事务不起作用

来源:互联网 发布:淘宝大量同城交易 编辑:程序博客网 时间:2024/04/30 00:13

自己写了个事务怎么改都不起作用 最后发现是mysql 数据库中的部分引擎不支持事务回滚

谢谢这篇文章的博主 http://blog.csdn.net/szwangdf/article/details/41516239

下文也是 此博主原创

最近在项目的时候碰到pring事务不起作用的情况,后来解决了,这里我汇总下:

 

1、首先使用如下代码 确认你的bean 是代理对象吗?

必须是Spring定义(通过XML或注解定义都可以)的Bean才接受事务。

直接new出来的对象添加事务是不起作用的。

可以通过以下方式判断是否是代理对象:

AopUtils.isAopProxy(Object object)

AopUtils.isCglibProxy(Object object) //cglib

AopUtils.isJdkDynamicProxy(Object object) //jdk动态代理


 2、入口函数必须是public,否则事务不起作用。这一点由Spring的AOP特性决定的。


 3、切入点配置错误。

<!-- 使用annotation注解方式配置事务 -->
<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>

<!--使用切面方式配置事务-->
<tx:advice id="txadvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" isolation="READ_COMMITTED" propagation="REQUIRED" rollback-for="java.lang.Exception" /> 
</tx:attributes>
</tx:advice>

<aop:config>
<aop:pointcut id="pointcut" expression="execution(* com.tyyd..*Service.do*(..))"/>
<aop:advisor advice-ref="txadvice" pointcut-ref="pointcut"/>
</aop:config> 


4、如果你使用了springmvc,可能是context:component-scan重复扫描引起的:


 

5、如使用mysql且引擎是MyISAM造成的(因为不支持事务),改成InnoDB即可。

1 0