Connection is read-only. Queries leading to data modification are not allowed 问题解决方式两种

  • 一、一种情况是在实现类中的类上边加的@Transactional(readOnly = true)所导致,
  •  	这种情况下可以在方法名上加注解@Transactional(readOnly = false)
    
  • 二、看看你的框架中是否有aop统一事务处理
  •  	限制了以个别方法名开头的事务,我的就是 用的 resume开头的方法,当时就是报错,当把resume开头的方法名,加进来之后,解决了,详情看下图
    
 	@Aspect
@Component
public class TransactionAdviceConfig {

    /**
     * 多个切入点表达式使用 and
     */

    private static final String AOP_POINTCUT_EXPRESSION = "execution(* com.test.*.service.impl.*.*(..))";

    @Autowired
    private PlatformTransactionManager transactionManager;

    @Bean
    public TransactionInterceptor txAdvice() {

        /**
         * 事务有以下几个常用属性:
         *
         * read-only:设置该事务中是否允许修改数据。(对于只执行查询功能的事务,设置为TRUE可以提高事务的执行速度)
         *
         * propagation:事务的传播机制。一般设置为required。可以保证在事务中的代码只在当前事务中运行,防止创建多个事务。
         *
         * isolation:事务隔离级别。不是必须的。默认值是default。
         *
         * timeout:允许事务运行的最长时间,以秒为单位。
         *
         * rollback-for:触发回滚的异常。
         *
         * no-rollback-for:不会触发回滚的异常。
         *
         * 实际开发中,对于只执行查询功能的事务,要设置read-only为TRUE,其它属性一般使用默认值即可
         **/
        //事务的传播行为
        DefaultTransactionAttribute txAttr_REQUIRED = new DefaultTransactionAttribute();
        txAttr_REQUIRED.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);

        //只读事务
        DefaultTransactionAttribute txAttr_REQUIRED_READONLY = new DefaultTransactionAttribute();
        txAttr_REQUIRED_READONLY.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
        txAttr_REQUIRED_READONLY.setReadOnly(true);

        NameMatchTransactionAttributeSource source = new NameMatchTransactionAttributeSource();

        source.addTransactionalMethod("remove*", txAttr_REQUIRED);
        source.addTransactionalMethod("update*", txAttr_REQUIRED);
        source.addTransactionalMethod("delete*", txAttr_REQUIRED);
        source.addTransactionalMethod("insert*", txAttr_REQUIRED);
        source.addTransactionalMethod("create*", txAttr_REQUIRED);
        // 我写的在这儿
        source.addTransactionalMethod("resume*", txAttr_REQUIRED);
        source.addTransactionalMethod("pause*", txAttr_REQUIRED);
        source.addTransactionalMethod("change*", txAttr_REQUIRED);

        /*使用以下字符开头命名的方法,开启只读模式,提高数据库访问性能*/
        source.addTransactionalMethod("get*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("query*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("find*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("list*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("count*", txAttr_REQUIRED_READONLY);
        source.addTransactionalMethod("select*", txAttr_REQUIRED_READONLY);
 

        return new TransactionInterceptor(transactionManager, source);
    }

    @Bean
    public Advisor txAdviceAdvisor() {
        AspectJExpressionPointcut pointcut = new AspectJExpressionPointcut();
        pointcut.setExpression(AOP_POINTCUT_EXPRESSION);
        return new DefaultPointcutAdvisor(pointcut, txAdvice());
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值