`

解决hibernate Subquery returns more than 1 row

阅读更多

使用hibernate时,发现一个错误:

        at java.lang.Thread.run(Thread.java:748)

Caused by: java.sql.SQLException: Subquery returns more than 1 row

        at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:54

 

SQL:

select
  inspection0_.houseInfo_id as col_0_0_,
  inspection0_.id as col_1_0_,
  inspection0_.agent_id as col_2_0_,
  (select
     distinct cooperatio2_.id
   from
     t_cooperationOrder cooperatio2_
   where
     cooperatio2_.primaryAgent_id=113
     and cooperatio2_.status>1
     and cooperatio2_.inspectionOrder_id=inspection0_.id ) as col_3_0_,
  houseinfo1_.id as id1_35_0_,
  inspection0_.id as id1_40_1_,
  houseinfo1_.address as address2_35_0_,
  houseinfo1_.agreeTotalPrice as agreeTot3_35_0_
from
  t_inspectionOrder inspection0_
  inner join
  t_houseInfo houseinfo1_
    on inspection0_.houseInfo_id=houseinfo1_.id
where
  (
    inspection0_.agent_id=113
    or 113 in (
      select
        cooperatio3_.secondaryAgent_id
      from
        t_cooperationOrder cooperatio3_
      where
        cooperatio3_.inspectionOrder_id=inspection0_.id
        and cooperatio3_.status>1
    )
  )
  and houseinfo1_.houseStatus=8
  and (
    inspection0_.status in (
      7 , 8
    )
  )
order by
  inspection0_.updateTime desc

 

解决方法:

以select * from table1 where table1.colums=(select columns from table2);这个sql语句为例。

1)如果是写入重复,去掉重复数据。然后写入的时候,可以加逻辑判断(php)或者外键(mysql),防止数据重复写入。
   (我实际开发中遇到的就是数据重复写入的情况,在数据库查到有相同的数据两条,这不符原本的原本的业务需求)
2)在子查询条件语句加limit 1,找到一个符合条件的就可以了
select * from table1 where table1.colums=(select columns from table2 limit 1);
3)在子查询前加any关键字
select * from table1 where table1.colums=any(select columns from table2);

(4)select * from table1 where table1.colums=any(select max(columns) from table2);

参考:

https://hedleyproctor.com/2014/08/hibernate-query-limitations-and-correlated-sub-queries/

https://blog.csdn.net/LY_Dengle/article/details/78028166

 

0
0
分享到:
评论

相关推荐

    hibernate N+1问题解决办法

    **标题:“Hibernate N+1问题解决办法”** 在Java开发中,使用Hibernate作为ORM框架时,我们可能会遇到一个性能上的问题,那就是著名的“N+1查询问题”。此问题源于不恰当的数据加载策略,可能导致数据库查询效率...

    如何使用MySQL一个表中的字段更新另一个表中字段

    1,修改1列 update student s, city c set s.city_name = c.name where s.city_code = c.code; 2,修改多个列 update a, b set a.title=b.title, a...oracle查询报这个错误:single-row subquery returns more than o

    oracle子查询教程(ppt )

    执行单行子查询时,确保子查询的结果只有一行,否则会引发错误,如示例中的 `ORA-01427: single-row subquery returns more than one row`。同时,子查询中不应包含`ORDER BY`子句,因为这会影响结果的顺序,而子...

    Oracle公司内部数据库培训资料Les06chinese.ppt

    例如,试图将一个员工的job_id与一个没有结果的子查询进行比较,会导致错误“ORA-01427: single-row subquery returns more than one row”。 8. **多行子查询与单行比较符**:使用多行子查询时,如果与单行比较符...

    mysql常见错误与标准错误对照表.docx

    11. **错误124221000**: "Subquery returns more than 1 row",子查询返回了多行结果,但预期只有一行。 12. **错误126422003**: "Out of range value adjusted for column '%s' at row %ld",表示试图插入的数据...

    oracle子查询PPT学习教案.pptx

    在使用子查询时,如果子查询返回多行而主查询期望单行结果,就会导致错误,如"single-row subquery returns more than one row"。 另外,子查询也可以与`GROUP BY`和`HAVING`子句结合使用。`GROUP BY`对数据分组,`...

    Laravel开发-eloquent-subquery-magic

    1. 子查询基础 子查询是在一个SQL查询中嵌套另一个完整的SQL查询,它可以作为选择、比较或者联接的数据源。在Laravel的Eloquent中,可以使用`DB::raw()`方法创建子查询。Eloquent Subquery Magic则提供了更高级的...

    row_number,根据多个字段过滤,partition by

    本篇文章将围绕如何利用`ROW_NUMBER()`函数结合`PARTITION BY`子句来实现基于多个字段的过滤操作,以解决在给定描述中的问题——即如何根据`name`、`idNumber`以及`date`这三个字段过滤教师表中的重复数据,并仅保留...

    hibernate子查询

    在使用Hibernate进行数据查询时,有时会遇到需要使用子查询的情况。然而,正如你所描述的,Hibernate的HQL(Hibernate Query Language)并不直接支持在`FROM`子句后跟一个子查询,这与标准的SQL语法有所差异。在HQL...

    \Hibernate_query条件查询

    1. **HQL(Hibernate Query Language)** HQL是Hibernate提供的面向对象的查询语言,类似于SQL,但操作的对象是对象而非表。例如,要获取所有用户,可以使用以下HQL语句: ```java Query query = session....

    Oracle中(column1,column2..)in(集合/子查询)的hibernate实现

    这篇博客文章“Oracle中(column1,column2..)in(集合/子查询)的hibernate实现”可能详细解释了如何在Hibernate中构建这种复杂查询。 首先,`Restrictions`是Hibernate Criteria API中的一个类,它提供了一系列的方法...

    SQL中row-number函数用法

    1. 使用 `ROW_NUMBER() OVER (ORDER BY id)` 对每一行进行编号。 2. 使用 `ROW_NUMBER() OVER (PARTITION BY Num ORDER BY id) - ROW_NUMBER() OVER (ORDER BY id)` 来标记出连续出现的数字。当数字连续时,这个差值...

    hibernate api英文

    1. Session接口:它是Hibernate的核心接口,负责对象的持久化操作,如保存、更新、删除和查询。Session维护了一个对象和数据库记录的映射,提供了事务管理和并发控制。 2. Transaction接口:处理数据库事务,确保...

    很全面的Hibernate查询介绍

    Project project = (Project) objects[1]; System.out.println("UserID: " + user.getId() + "\tProject Name: " + project.getName()); } ``` 除此之外,Hibernate 还提供了 HQL(Hibernate Query Language)...

    Hibernate的Criteria用法

    Hibernate的Criteria API是一种用于动态构建SQL查询的方法,无需手动编写HQL(Hibernate Query Language)语句。它提供了一种面向对象的方式来构建查询条件,使得代码更加简洁且易于维护。以下是对Criteria用法的...

    《Pro Oracle SQL》Chapter 10.2.5 Applying Subquery Factoring to PL/SQL

    在Oracle SQL的世界里,"Subquery Factoring"(也称为"Common Table Expression"或CTE)是一种高效且灵活的查询构造技术,它允许我们将复杂的子查询重用并简化查询语句。这一概念在《Pro Oracle SQL》的第10章第2.5...

    《Pro Oracle SQL》Chapter 9 -- 9.11 Subquery Factoring

    WITH cte_name (column1, column2, ...) AS ( subquery ) SELECT ... FROM cte_name WHERE ... ``` 在这里,`cte_name`是你定义的临时表名,`subquery`是你要执行的子查询,其结果会被存储为一个临时表。然后在`...

    《Pro Oracle SQL》Chapter 10 Subquery Factoring --10.1 Standard Usage

    《Pro Oracle SQL》第10章"Subquery Factoring"深入探讨了这一主题,尤其是10.1节“Standard Usage”部分,讲解了子查询在实际应用中的常见用法。在本章节中,作者可能详细阐述了如何利用子查询来优化SQL语句,提高...

Global site tag (gtag.js) - Google Analytics