当前位置: 首页 > 面试题库 >

Java JDBC延迟加载的ResultSet

宰父远
2023-03-14
问题内容

有没有一种方法可以让您通过运行JDBC查询来延迟加载而获得ResultSet?我希望每行都按我的要求而不是事先加载。


问题答案:

简短答案:

Statement.setFetchSize(1)致电前使用executeQuery()

长答案:

这取决于 非常 多的哪个JDBC驱动程序所使用。您可能需要看一下该页面,该页面描述了MySQL,Oracle,SQL Server和DB2的行为。

主要外卖:

  • 每个数据库(即每个JDBC驱动程序)都有其自己的默认行为。
  • 一些驾驶员会setFetchSize()毫无保留地予以尊重,而其他一些则需要一些“帮助”。

MySQL是一个特别奇怪的情况。看到这篇文章。听起来像是如果您致电setFetchSize(Integer.MIN_VALUE),那么它将一次下载一行,但这还不是很清楚。

另一个例子:这是
PostgreSQL行为的文档。如果打开了自动提交功能,则ResultSet将立即获取所有行,但是如果关闭,则可以setFetchSize()按预期使用。

要记住的最后一件事:这些JDBC驱动程序设置仅影响客户端发生的情况。服务器可能仍会将整个结果集加载到内存中,但是您可以控制客户端如何 下载 结果。



 类似资料:
  • 描述 (Description) 延迟加载可应用于图像,背景图像和淡入效果,如下所述 - 对于图像 要在图像上使用延迟加载,请按照给定的步骤进行操作 - 使用data-src属性而不是src属性来指定图像源。 将类lazy添加到图像。 <div class = "page-content"> ... <img data-src = "image_path.jpg" class = "l

  • 问题内容: 如果这是完全相同的内容,请纠正我,我知道这个话题经常被讨论,但是找不到确切的答案。 问题: 在MVC Web应用程序中处理Hibernate对象的最佳实用解决方案是什么? 细节: 我正在使用Hibernate,并希望在可能的情况下利用延迟加载。 我正在使用MVC风格的Webapp。 我讨厌获得延迟加载初始化异常。 我讨厌不得不在事务之间重新连接Hibernate对象。 选项: 渴望装载

  • 问题内容: 我在JPA实体中的延迟加载属性有问题。我读过许多类似的问题,但它们与spring或hibernate有关,并且他们的后代不适用或没有帮助。 该应用程序是在Wildfly应用程序服务器上运行的JEE和JPA2.1。有两个实体,DAO会话bean和servlet将它们放在一起: 当我运行此代码时,它失败并显示: 我对WebLogic / JPA1使用了非常相似的模式,并且运行平稳。任何的想

  • 问题内容: 我想知道在node.js中使用是否等效于延迟加载? 例如,如果我有一个函数需要代码中其他任何地方都不需要的特定node.js包,那么我最好在该函数内部使用它,以便仅在调用该函数时才包含所需的包。 我还不确定是否会由于缺乏对node.js架构的了解而在性能方面有所改善?我想它每次与服务器的连接都会使用更少的内存。但是,当它必须读取程序包时,它会增加磁盘的I / O吗,还是将其添加到内存中

  • 这是从这里开始的后续行动。 我正在实现一个表,它将数据异步加载到表单元格中。问题是,表单元格有时无法正确更新。有时它会以某种方式“挂起”并永远显示“加载...”。实际值只有在我在表中滚动一点时才会更新。 要复制,请在表格中快速向下滚动应用程序。某些单元格不会显示“延迟加载”值,而是显示占位符字符串。 延迟加载属性如下所示: } 应用程序如下所示: 完整的可运行代码可以在这里找到。

  • 有很多关于“懒惰”的例子和文档。也许我没有明白,但为什么要用它呢?实例化bean成本