aop对使用@Transactional注解出现异常时不能自动回滚的问题

在service类的方法上加了@Transactional,没有使用try{}catch(){},却不能自动回滚,最后发现我对trans的方法加了aop做日志记录,而日志处理的方法上使用了trycatch异常没有抛出,事务无法回滚。于是在catch里让它抛出异常,
throw new RuntimeException(throwable.getMessage());问题就解决了

@Around("pt()")
    public Object logAround(ProceedingJoinPoint pjp) {
        Object[] args = pjp.getArgs();
        Object proceed = null;
        try {
            proceed = pjp.proceed(args);
            if (proceed.toString().equals("false")) {
                tradeService.insertLog(args[0].toString(),"交易失败", (Double) args[2],"接收账号:"+args[1].toString());
            }
            tradeService.insertLog(args[0].toString(), "转出", (Double) args[2], "接收账号:" + args[1].toString());
            return proceed;
        } catch (Throwable throwable) {
            tradeService.insertLog(args[0].toString(), "交易失败", (Double) args[2], "交易中断");
            throw  new RuntimeException(throwable.getMessage());

        }

    }

你可能感兴趣的:(java学习,java笔记)