• Connection is read-only解决方式


    题外话,很少在网上公开写东西,不是没有分享精神,只是害怕自己也是略懂会误导其他人,所以每次解决完问题都是在印象笔记上记录,只供自己方便查阅。上一次写还是2016年的事情,转眼已经到了2018年了,我也从iOS开发现在慢慢转成java开发,要学习的东西真的很多,幸好有一颗喜欢编程的心,要不然真的不知道这几年是怎么过来的。

    正文:

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

    我产生的原因:自己在mybatis中写了一个插入的sql语句,对应的dao层service层也都写了相应的删除方法,但是controller在调用的时候,报错。

    这个错误其实已经很明显,提示我修改不被允许,是只读的。网上也都有答案,让修改spring-context.xml配置文件,例如:

    这里面有写到,必须要以配置的这些单词开头才行,例如可以叫insertUserInfo,但是不能叫saveUserInfo,因为并没有save开头的,其他开头的单词都是read-only=true

    于是乎在我的工程中搜索类似字样,却发现并没有这些配置,然而我又是刚接触这些框架没多久不太敢轻易添加这些标签,所以问题持续了好久,猛然间发现某个service层中的方法上有个注解@Transactional(readOnly = false) 很明显声明事务的只读性为false,于是在我自己写的方法上也加了这么行语句,问题得以解决,可能用一段时间这些框架后再回头看这些文章会觉得自己很傻逼吧,但记录出来,希望能对像我这样的框架小白有点帮助。

    附详细代码,最主要的是第一行声明一下不是只读,否则默认应该是只读:

    service

     dao

    mybatis

    最后,用这么大的篇幅写了这么一个小错误,只当为了激励自己码好自己的代码。

    来自:https://www.cnblogs.com/fiving1314/p/8534680.html

  • 相关阅读:
    后缀数组板子
    上海高校金马五校赛 J
    西安电子科技大学第16届程序设计竞赛网络同步赛 G-小国的复仇
    HDU
    string 与char* char[]之间的转换 .
    (分治思想)(归并排序)C
    如何取出 Map中key和value的值
    C++ STL 中 map 容器的说明和使用技巧 .
    (经典map)A
    Babelfish(6.1.2)(sort结构体排序)(sscanf()基本使用方法)(二分法)
  • 原文地址:https://www.cnblogs.com/xp20170618/p/14448906.html
Copyright © 2020-2023  润新知