zoukankan      html  css  js  c++  java
  • 执行update操作的话,就会报“Connection is read-only. Queries leading to data modification are not allowed”的异常。

    我用的是 spring + springmvc + mybatis +mysql、

    <tx:advice id="txAdvice" transaction-manager="txManager">
            <tx:attributes>
                <tx:method name="save*" propagation="REQUIRED" />
                <tx:method name="add*" propagation="REQUIRED" />
                <tx:method name="update*" propagation="REQUIRED" />
                <tx:method name="modify*" propagation="REQUIRED" />
                <tx:method name="delete*" propagation="REQUIRED" />
                <tx:method name="remove*" propagation="REQUIRED" />
                <tx:method name="select*" read-only="true" /> 
                <tx:method name="query*" read-only="true" />
                <tx:method name="get*" read-only="true" />
            </tx:attributes>
        </tx:advice>

     让所有的方法都加入事务管理,为了提高效率,可以把一些查询之类的方法设置为只读的事务

    <!-- method name=*, readonly=true表示所有的数据库操作都可以使用,但是只能是读取数据库

    但是如果是UserService的方法delUser, 要在dao层删除用户。就会报错误如下:

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

    出现这个问题的原因是默认事务只有只读权限,因此要添加下面的每一个add*,del*,update*等等。 分别给予访问数据库的权限。

    还有就是在service层中在只有只读权限的方法中调用操作数据库的方法也会报错Connection is read-only. Queries leading to data modification are not allowed。 

    例如  

    1 public String getXX(){
    2            server.updateXX(obj);
    3 }

     例如在get方法中调用了update方法但是get只有只读权限,所以需要修改方法名或者将配置文件修改为

        <tx:method name="get*" read-only="false" />
  • 相关阅读:
    Cryptography中的对称密钥加解密:fernet算法探究
    HTTPS的工作原理
    最近要写的博客
    浅谈路由器软硬件架构
    组管理、权限管理、定时任务调度、磁盘分区
    matplotlib数据可视化
    tensorflow实现简单的卷积神经网络
    tensorflow实现简单的感知机
    tensorflow实现简单的自编码器
    区域生长算法(手动选取种子点)MATLAB
  • 原文地址:https://www.cnblogs.com/dashuai01/p/5085560.html
Copyright © 2011-2022 走看看