解决jpa查询语句自动变成了update的问题

 更新时间:2021年08月06日 08:59:58   作者:YYZhQ  
这篇文章主要介绍了解决jpa查询语句自动变成了update的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

jpa查询语句自动变成了update

今天碰到了个奇怪的问题,明明dao中一个查询函数,一直报connection read-only错误,断点设置过去,发现明明一个select 查询语句,一直到生成Query查看变量里面都是查询的代码,可一执行就变成了update,简直见了鬼了。

我的架构是sshj,层次也就是entity,dao,service,action,代码如下,非常简单的代码:

dao层:

public boolean findCanXiaohu(String code) {
  try {
   String queryStr = "  select count(*) from t_tablename ";
   Query query = em.createNativeQuery(queryStr);
   Long res = (Long) query.getSingleResult();
   if (res > 0) {
    return false;
   } else {
    return true;
   }
  } catch (Exception e) {
   return true;
  }
 }

serivce层:

public boolean getCanXiaohu(String code){
  return dao.findCanXiaohu(code);
 }

action层:

public String edit(){
  String res =  super.edit();
  if ("1".equals(entity.getYhzhanghuxingzhi())) {
   String code = entity.getYhcunkuanrenbianhao();
   canXiaohu = service.getCanXiaohu(code);
  } else {
   canXiaohu = true;
  }
  return "input";
 }

刚开始我以为是因为在action层我写进了prepareModel方法中,这个方法按道理也没有写入数据库操作,但以防万一吧,我改到了edit方法下,这个方法也就是打开一个编辑页面,其prepareEdit函数中执行了prepareModel,也不过根据传递的id从数据库中查找entity。

奇怪就奇怪在一执行到getCanXiaohu,看断点也执行到了dao.findCanXiaohu(),实话说,我在前面查找问题过程中,还把函数名都改成这样了,原来没有前缀find、get,就如同上面说的,我断点设置到查询语句,一步步执行,生成query的时候看里面的语句还是select,可一执行到query.getSingleResult(),它就直接异常,然后看输出的语句,就成了一个update t_table的语句,其中的set语句set 各字段的值,因为这个函数是查询函数,没加事务,所以不能执行update,所以就会异常出错。但它就是个查询,我也并不打算做修改,不知道为什么会出这样的问题,怎么改都不行,也搞不明白是怎么回事。

我就各种试,最后, 我把语句改成了jpql标准语句,然后,居然可以了!!!!!!

public boolean findCanXiaohu(String code) {
  try {
   String queryStr = "  select count(o) from ClassName o ";
   Query query = em.createQuery(queryStr);
   Long res = (Long) query.getSingleResult();
   if (res > 0) {
    return false;
   } else {
    return true;
   }
  } catch (Exception e) {
   return true;
  }
 }

不报错了,也执行查询了,虽然成功了,可我还是不知道是怎么回事。

JPA框架中UPDATE语句问题

一定要加上下面这个两个注解啊啊啊啊啊!!!!!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • springboot AutoConfigureAfter控制Bean的注入顺序方法详解

    springboot AutoConfigureAfter控制Bean的注入顺序方法详解

    这个文章主要介绍一下@AutoConfigureAfter在spring框架中的作用,在使用过程中,很多开发人员在使用它的时候都出现了问题,问题比较多的就是它们的注册顺序总不是我们预期的,下面介绍一下正常的使用方法,感兴趣的朋友一起看看吧
    2024-05-05
  • Java IO之序列化与反序列化详解

    Java IO之序列化与反序列化详解

    这篇文章主要为大家介绍了Java IO之序列化与反序列化,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • java实现马踏棋盘游戏

    java实现马踏棋盘游戏

    这篇文章主要为大家详细介绍了java实现马踏棋盘游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Eclipse查看开发包jar里源代码的方法

    Eclipse查看开发包jar里源代码的方法

    这篇文章主要介绍了Eclipse查看开发包jar里源代码的方法的相关资料,需要的朋友可以参考下
    2017-07-07
  • java数据结构实现顺序表示例

    java数据结构实现顺序表示例

    这篇文章主要介绍了java数据结构实现顺序表示例,需要的朋友可以参考下
    2014-03-03
  • JDK与JRE的下载和安装以及配置JDK环境变量图文教程

    JDK与JRE的下载和安装以及配置JDK环境变量图文教程

    JRE也就是(Java RuntimeEnvironment)Java运行环境,是运行JAVA程序所必须的环境的集合,包含各种类库,下面这篇文章主要给大家介绍了关于JDK与JRE的下载和安装以及配置JDK环境变量的相关资料,需要的朋友可以参考下
    2023-12-12
  • Mybatis-Plus实现自动生成代码的操作步骤

    Mybatis-Plus实现自动生成代码的操作步骤

    AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率,本文将给大家介绍Mybatis-Plus实现自动生成代码的操作步骤
    2023-10-10
  • 探究实现Aware接口的原理及使用

    探究实现Aware接口的原理及使用

    这篇文章主要为大家介绍了探究实现Aware接口的原理及使用,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • Java打印九九乘法表代码详情

    Java打印九九乘法表代码详情

    这篇文章主要介绍了Java打印九九乘法表,使用了双重for循环,使用do{}while()实现打印九九乘法表这些好玩的语法实现,感兴趣的小伙伴可参考下面文章内容
    2021-09-09
  • IDEA引入本地jar包的几种方法

    IDEA引入本地jar包的几种方法

    本文主要介绍了IDEA引入本地jar包的几种方法,文中通过图文结合的方式码介绍的非常详细,对大家的学习或工作有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2024-01-01

最新评论