一旦我用oracle驱动程序使用jdbc并运行select查询是将查询的结果存储在oracle内存或文件系统还是临时表的服务器中?
一旦我运行下一个方法,通过获取下一行是从oracle服务器内存加载到jvm内存?
如果我将结果集上的取数大小定义为1000,这意味着1000行从oracle加载到JVM上的JDBC驱动程序?
解决方法
默认行数(不是整个结果集)将在本地内存中获取.一旦你到达所获取的行的最后一行(比如说做next()并尝试访问下一行),并且如果结果中有更多的行,那么将进行另一个往返调用到数据库以获取下一个批次行.
编辑1:
您可以通过执行此操作查看结果集一次提取的行数(请验证语法):
rs.beforeFirst(); // will put cursor before the first row rs.last(); // will put cursor after the last line int noOfRows = rs.getRow(); // will give you the current row number
编辑2:
如果您希望在本地内存中获得比平常更多的行,则可以考虑使用CachedRowSet.即使这样也可以进行往返行程,但通常会低于正常的结果集.但是,您应该考虑对应用程序进行一些性能检查.