• Connection is read-only. Queries leading to data modification are not allowed


    后台对数据进行操作时遇到这个问题 是事务的保护机制

    事务管理对于企业应用来说是至关重要的,即使出现异常情况,它也可以保证数据的一致性。

    spring支持编程式事务管理和声明式事务管理两种方式。

       编程式事务管理使用TransactionTemplate或者直接使用底层的PlatformTransactionManager。对于编程式事务管理,spring推荐使用TransactionTemplate。

      声明式事务管理建立在AOP之上的。其本质是对方法前后进行拦截,然后在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务。

      声明式事务管理也有两种常用的方式,一种是基于tx和aop名字空间的xml配置文件,另一种就是基于@Transactional注解。显然基于注解的方式更简单易用,更清爽。

           当作用于类上时,该类的所有 public 方法将都具有该类型的事务属性,同时,我们也可以在方法级别使用该标注来覆盖类级别的定义。

    加了事务注解的类里面,当方法对数据库进行操作的时候就会出现 Connection is read-only. Queries leading to data modification are not allowed 这个报错解决办法就是在方法上加上

    @Transactional(readOnly = false, rollbackFor = Exception.class)

     就可以解决问题了

    在@Transactional注解中如果不配置rollbackFor属性,那么事物只会在遇到RuntimeException的时候才会回滚,加上rollbackFor=Exception.class,可以让事物在遇到非运行时异常时也回滚

    附图:

  • 相关阅读:
    java.lang.NoClassDefFoundError:org/apache/commons/lang/exception/NestableRuntimeException错误的解决
    json转换成对象
    16年4月20号 个人总结
    sql between and
    sql 中的运算符级别 如and or not
    mybatis int 类型判断<if>
    iOS地址编码解析
    iosiOS 地图 自定义以及添加锚点
    ios如何获取位置权限
    如何初始化一个iOS原生地图
  • 原文地址:https://www.cnblogs.com/cmm123/p/13947698.html
Copyright © 2020-2023  润新知