假设我必须遍历所有的条目,有人知道ResultSet的结果是如何获取的吗?
我是否可以调用SELECT * FROM MyTable
而不是SELECT TOP 100 * FROM MyTable ORDER BY id ASC OFFSET 0;
,只在需要时调用resultSet.next()
来获取结果,并在程序级别上处理它们,或者结果是否已经在内存中而没有放入TOP
是不好的?
发布于 2019-03-09 13:54:52
ResultSet
类公开一个
void setFetchSize(int rows)
方法,其中,每个JavaDoc
提示JDBC驱动程序,当此
ResultSet
对象需要更多行时,应该从数据库中获取的行数。
这意味着,如果我们拥有数据库中的200
行的结果集,并且将获取大小设置为100
,那么~100
行将一次从数据库中加载,并且可能需要两次访问数据库。
默认的获取大小依赖于驱动程序,但例如,Oracle
将其设置为10
行。
https://stackoverflow.com/questions/55077972
复制相似问题