spring事务和aop同时使用,事务不生效

spring事务和aop同时使用

对同一个类即用aop又用事务,需要指定代理顺序,保证事务的代理包裹aop的代理,也就是事务的order大于aop的order,否则事务会失效,也就是不会回滚。

  • 使用aop的地方设置order如下:
@Order(1)
@Component
@Aspect
public class AopDaoRunTime {
    private static final Logger LOGGER = LoggerFactory.getLogger(AopDaoRunTime.class);
    @Around("execution(* com.qunar.lfz.dao.impl.*.*(..))")
    public Object printDaoTime(ProceedingJoinPoint point) {
        String methodName = point.getSignature().getName();
        Object result = null;
        try {
            long startTime = System.currentTimeMillis();
            result = point.proceed();
            long endTime = System.currentTimeMillis();
            LOGGER.info("{}方法执行时间为{}ms", methodName, endTime - startTime);
        } catch (Throwable e) {
            LOGGER.error("获得dao执行方法时间出错", e);
            return null;
        }
        return result;
    }
}
  • 配置spring事务和aop的xml:
    <aop:aspectj-autoproxy proxy-target-class="true" />
    <tx:annotation-driven transaction-manager="transactionManager" order="2"/>
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="xxx"/>
    </bean>

aop的配置中指定proxy-target-class="true",会使用cglib生成子类做代理,现在的cglib效率比jdk的基于接口的代理效率高很多
需要注意的是如果使用的是代理对象,对属性的读写都要通过get、set方法来做。代理对象的属性都是null,通过get、set方法才能读写被代理对象中的属性

  • spring手动回滚

TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();

肥肥小浣熊
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,850评论 19 139
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,490评论 11 349
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,126评论 6 342
  • 转自:http://blog.csdn.net/jackfrued/article/details/4493116...
    王帅199207阅读 7,475评论 0 19
  • 今天和导演聊天,人家要考北航的马克思主义理论。我很佩服,我俩约定好我去北航找她,她来师大找我。我觉得北航是不好考,...
    赏心悦事阅读 1,166评论 0 0

友情链接更多精彩内容