ResultSet.next 始终为 false,表格已填充

Posted

技术标签:

【中文标题】ResultSet.next 始终为 false,表格已填充【英文标题】:ResultSet.next always false, table populated 【发布时间】:2017-06-13 01:29:11 【问题描述】:

我的桌子:

create table ranking (rennId int not null, fId int not null, pos int not null, CONSTRAINT key PRIMARY KEY (rennId,fId))

我的java代码:

try 
    Connection con = DriverManager.getConnection(url, user, password);
    ResultSet ret = con.createStatement().executeQuery("select * from ranking");
    while (ret.next())
        System.out.println("test");
 catch (SQLException e)  e.printStackTrace();    

手动测试:

sql> select * from ranking
[2017-06-13 03:21:59] 3 rows retrieved starting from 1 in 52ms (execution: 45ms, fetching: 7ms)

独立测试 只出现在这张桌子上

【问题讨论】:

我相信这是 try-with-resources 的约定,以保证在表达式完成执行后关闭 try 子句中指定的资源。我相信结果集也在 try 块的末尾被关闭,因此调用 next() 返回 false,因为那里什么都没有 @user7790438 但是对结果的循环完全在 inside try 块中。为什么你会期望在那个时候关闭任何资源? create查询和select查询中的表名是不是目的不同? @SHG 抱歉复制粘贴失败,它们是一样的 @user7790438 next on a closed 结果会引发错误,即使经过测试是否确实如此,但这里并非如此 【参考方案1】:

显然这是与 DataGrip 结合的问题。 此代码实际上选择了在此应用程序中创建的所有条目,但忽略了通过 DataGrip 创建的所有条目。 似乎与组合主键有关

【讨论】:

以上是关于ResultSet.next 始终为 false,表格已填充的主要内容,如果未能解决你的问题,请参考以下文章

Mockito - 模拟ResultSet

jdbc如何判断记录集是否为空?用啥方法?ResultSet本身是否根本就没有这样的方法?

java.sql.SQLException: 关闭的 Resultset: next

Java JDBC结果集的处理

ResultSet next方法

为啥最后一次“ResultSet.next()”迭代比之前的迭代花费更多的时间?