- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我收到下面的错误,说有堆栈溢出。发生这种情况是因为带有 IN (id, id, id...id)
的 SQL 语句有大量参数。有没有什么办法解决这一问题?这是在我使用 Eclipse 的本地环境中发生的。
JPA
@Query(value="SELECT p FROM PendingCourseRegistration p WHERE p.sisId IN ?1 AND p.testId = ?2")
List<PendingCourseRegistration> findPendingCourseRegistrationInSisIdsAndTestId(List<String> sisIds, Long testID);
错误
java.lang.StackOverflowError: null
at java.lang.Abstract witingBuilder.append(AbstractStringBuilder.java:416) ~[na:1.7.0_17]
at java.lang.StringBuffer.append(StringBuffer.java:237) ~[na:1.7.0_17]
at antlr.BaseAST.toStringList(BaseAST.java:341) ~[antlr-2.7.7.jar:na]
at antlr.BaseAST.toStringList(BaseAST.java:347) ~[antlr-2.7.7.jar:na]
at antlr.BaseAST.toStringList(BaseAST.java:347) ~[antlr-2.7.7.jar:na]
at antlr.BaseAST.toStringList(BaseAST.java:347) ~[antlr-2.7.7.jar:na]
hibernate 查询
2:26.763 [ocPifScheduler-1] DEBUG o.s.o.j.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler - Creating new EntityManager for shared EntityManager invocation
09:52:26.788 [Scheduler-1] DEBUG org.hibernate.hql.internal.ast.QueryTranslatorImpl - parse() - HQL: SELECT p FROM com.test.PendingCourseRegistration p WHERE p.sisId IN (:x10_, :x11_, :x12_, :x13_, :x14_, :x15_, :x16_, :x17_, :x18_, :x19_, :x110_, :x111_, :x112_, :x113_, :x114_, :x115_, :x116_, :x117_, :x118_, :x119_, ...:xN) AND p.id = ?2
09:52:26.891 [Scheduler-1] DEBUG org.hibernate.hql.internal.ast.QueryTranslatorImpl - --- HQL AST ---
\-[QUERY] Node: 'query'
+-[SELECT_FROM] Node: 'SELECT_FROM'
| +-[FROM] Node: 'FROM'
| | \-[RANGE] Node: 'RANGE'
| | +-[DOT] Node: '.'
| | | +-[DOT] Node: '.'
| | | | +-[DOT] Node: '.'
| | | | | +-[DOT] Node: '.'
| | | | | | +-[DOT] Node: '.'
| | | | | | | +-[DOT] Node: '.'
| | | | | | | | +-[IDENT] Node: 'com'
| | | | \-[IDENT] Node: 'model'
| | | \-[IDENT] Node: 'PendingCourseRegistration'
| | \-[ALIAS] Node: 'p'
| \-[SELECT] Node: 'SELECT'
| \-[IDENT] Node: 'p'
\-[WHERE] Node: 'WHERE'
\-[AND] Node: 'AND'
+-[IN] Node: 'in'
| +-[DOT] Node: '.'
| | +-[IDENT] Node: 'p'
| | \-[IDENT] Node: 'sisId'
| \-[IN_LIST] Node: 'inList'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x10_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x11_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x12_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x13_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x14_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x15_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x16_'
| +-[COLON] Node: ':'
| | \-[IDENT] Node: 'x17_'
最佳答案
在我们使用 Hibernate 4.3.1.Final 的 Grails 项目 (2.3.6) 中,我们从未遇到过该错误,但由于查询缓冲区大小 限制,我们遇到了另一个错误:
由于您正在使用 in (?, ..., ?)
您编写的 ?,
与列表中的项目一样多,这意味着对于大list(说 50000)你可能写了一个 100000 个字符的查询,你可能有这个异常(这里有 pgSQL 驱动程序):
Foobar.executeQuery("select f from Foobar f where f.id in (:ids)",
[ids: 1L..100000L]); // Groovy way of creating a list of 100000 items.
错误:
SqlExceptionHelper:146 - An I/O error occured while sending to the backend.
SqlExceptionHelper:146 - This connection has been closed.
这就是我认为你可能需要的原因
要么将您的 id 列表拆分为更小的列表(例如 500 项左右)并手动合并结果,这比您使用的默认 spring-data 要做更多的工作。
<要么将 id 列表存储到一个临时表中(使用 JPA 可能会证明这是一项痛苦的任务)。临时表将是 (key, sids) 的元组。您将生成一个临时 key (用于 session ),使用该 key 将 ID 批量插入到该表中,刷新以便 hibernate 将更改推送到数据库中,使用该表使用子查询(p.sidIds in(选择sisIds from IdTable where key = ?1)
), 从该表中删除数据。虽然这是一项痛苦的任务,但它可能会提高性能。
关于java - Stackoverflow 和 Hibernate 使用 sql IN (id, id, id, id..id),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25310030/
使用 htaccess 我能够隐藏文件扩展名,使其成为/home 而不是/home.html。但是,对于主页,我想完全隐藏文件名,例如 stackoverflow.com,而不是 stackoverf
我试图在关闭子窗体时关闭我的主(父)窗体。然而,这给了我一个 StackOverflow 异常。 但是,如果我在 FormClosed 事件上调用 _child.Dispose,它会按预期工作。我应该
我在 IDEA 中使用 Gradle 并得到以下输出。 * What went wrong: A problem occurred evaluating script. > java.lang.Sta
我是一个 java 新手,并且在 StackOverflow 错误/在类之间访问文件的能力方面遇到了一个非常令人困惑的问题。我知道根本原因可能是我进行了一些递归调用,但修复它的语法却让我无法理解。我认
我需要编写一个程序来生成一些随机数,而不让两个数字落在某个范围内。不幸的是,我需要在学校做这件事,而我在计算机上唯一可以使用的语言是 Java(否则我会用 C++ 来做)。我对 Java 知之甚少,我
尝试设置一个 Person 类 我在尝试将信息封装在类中以使其不会被意外更改时遇到了问题。除了当我尝试使用 setter/getters 进行封装时,该类工作得非常好。我认为问题是这些方法最终会互相循
使用 scala,我已将大约 100000 个节点添加到链表中。当我使用函数 length 时,例如 mylist.length。我收到“java.lang.StackOverflowError”错误
我正在开发一个学校项目,该项目必须有 3 个带 1 个指针的快速排序、3 个带 2 个指针和 2 个堆的快速排序。 到目前为止,我已经编写了快速排序和堆之一。我遇到的问题是快速排序在小情况下工作正常,
我正在制作一个程序,它生成列表的所有子集,然后排列所有这些子集。我有一个生成子集的方法和一个生成排列的方法。但是,它们不能一起工作,即当我排列子集时,我没有得到子集的所有排列,并且出现 StackOv
我有以下函数,它应该产生笛卡尔平面中的所有坐标,我可以在n步中从原点到达: 原点是“位置”,步数是“强度”,它是一个 1-10 的整数。但是,我不断收到 stackoverflow 错误。每次我调用它
当我尝试使用 scala lib(使用 re2)匹配上述正则表达式时,代码进入以下路径并超时 1 分钟: 正则表达式: (([a-z0-9!#$%&'*+?^_`{|}~-]+(?:.[a-z0-9!
我正在开发一个运输 map 项目。我为该位置创建了一个名为 Chart 的对象和一个名为 Pos 的对象。我无法开始工作的是,当我从文本文件读取图表以正确创建对象 Pos 时,因为这就是失败的地方。
public class SortAnimal { public static Comparator getAnimalTagComparator() { return
我因使用以下泛型而收到 StackOverflowError: 积分: package me.expdev.gkitpvp; /* * Project created by ExpDev */ i
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我为一些命题逻辑表达式编写了一个javaCC解析器。表达式可能会很长,有 30k 个字符。 当我解析如此大的表达式时,出现堆栈溢出异常。 是否有一些虚拟机参数决定堆栈大小? 或者在这种情况下你会怎么做
这个问题已经有答案了: What is a StackOverflowError? (15 个回答) 已关闭 8 年前。 最高数字double可以代表极高,我想。尽管下面的代码会抛出异常。这实际上是我
我正在为我的 API 构建一个 SDK,其中有两个模块,分别是 A 类和 B 类。 public class A{ public final B = new B(); public f
执行此递归时,我收到堆栈溢出错误。有一个模式,它第一次说: at MazeGui.move(MazeGui.java:79) which is line if(rigting.goal == true
我编写的这段代码在达到一定的输入大小之前效果很好。如果输入太大,我会收到“java.lang.StackOverflowError”。我已经阅读了 stackoverflow 上有关此主题的其他一些条
我是一名优秀的程序员,十分优秀!