由于Resultset的大小,我需要在作业中使用HibernateCursorItemReader,但是我不能使它与EntityGgraph一起工作来急切地获取一些关系。我正在使用QueryProvider。
如果没有任何EntityGgraph,则不会发生连接,并且读取器可以正常工作,但是在批次处理作业期间,Hibernate会执行大量SQL查询以懒惰地获取数据。这导致处理非常缓慢。
通过查询提示获取它,任务在Loader.class的这一点冻结:
ResultSet rs=session.getJdbc协调器(). getResultSet返回().提取(st);
上面的代码是在HibernateCursorItemReader的
doOpen
方法中调用的,在第一项之前。没有错误,没有堆栈跟踪,几分钟内什么都没有,直到我停止JVM。
我现在使用HibernatePagingItemReader,使用相同的QueryProvider和提示来急切地获取数据。但是当获取具有集合的实体时,分页效率不高,JVM经常缺乏内存。
很抱歉缺少示例代码,但我所拥有的是上述类的默认配置和实现,没有具体的说明。我认为游标阅读器是解决方案,但它如何与EntityGraph一起工作呢?
编辑1
似乎实体图形和HibernateCursorItemReader在一起没有什么问题。耐心等待更多时间,处理开始了。它只是比通常慢,但是hibernate的游标读取器的工作方式与分页读取器相同,获取所有实体图。
似乎实体图形和HibernateCursorItemReader在一起没有什么问题。耐心等待更多时间,处理开始了。它只是比通常慢,但是hibernate的游标读取器的工作方式与分页读取器相同,获取所有实体图。
知道为什么下面的代码会出现以下错误吗? java.lang.NullPointerException:org.springframework.batch.item.database.HibernateCursoritemReader.DoRead处为null(HibernateCursoritemReader.java:155)
问题内容: 关于它们有很多传说。我想知道真相。以下两个示例之间有什么区别? 问题答案: 不确定从何处获得传说,但: 提交按钮 与: IE6将在标记之间提交此按钮的所有文本,其他浏览器将仅提交值。使用可使您在按钮的设计上享有更大的布局自由度。从各种意图和目的看,它乍一看似乎很棒,但是各种浏览器怪癖使它有时很难使用。 在您的示例中,IE6将发送到服务器,而其他大多数浏览器将不发送任何内容。要使其跨浏览
什么区别以及如何正确重写代码?
我试图理解为什么下面两个代码块会产生不同的结果。 代码块1按预期工作,并返回从数据库中查找的提供程序的数组。另一方面,代码块2返回函数数组。在理解promissione.all()和async/await时,我觉得缺少了一些简单的东西。 代码块的差异如下: > 块1:创建许诺函数数组,然后使用map运算符将其包装在异步函数中。 块2:许诺函数的数组被创建为异步函数。因此,不调用map运算符。 如果
问题内容: 我才刚刚开始研究SQL。 我有一个SQL Server 2008r2数据库,它将返回两个字段DocDate和InvValue。我需要将InvValues汇总为今天的MTD和YTD,所以看起来像 我已经做了大量的Google搜寻,并且可以使用SUM&DATEPART进行一项或多项,但是我坚持尝试两者兼而有之。 有人可以给我一些伪代码,以帮助我进一步谷歌。 谢谢@戈登·利诺夫(Gordon
这个示例代码来自一本Java书籍,从墙上的99瓶啤酒到没有啤酒打印出这首歌。问题是,当墙上是1瓶啤酒时,它仍然写着瓶子。我试图通过在末尾添加部分来解决这个问题。但是,它仍然显示1瓶啤酒在墙上,我瓶啤酒在墙上。 我不知道该改变什么来解决这个问题。是否创建另一个while部分? 如果你能给他们一个提示,这样我就可以自己解决它,那也很酷!因为我知道我的实际歌曲输出是在第一个if部分,但我不知道我应该在哪