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 但是对结果的循环完全在 insidetry
块中。为什么你会期望在那个时候关闭任何资源?
create查询和select查询中的表名是不是目的不同?
@SHG 抱歉复制粘贴失败,它们是一样的
@user7790438 next on a closed 结果会引发错误,即使经过测试是否确实如此,但这里并非如此
【参考方案1】:
显然这是与 DataGrip 结合的问题。 此代码实际上选择了在此应用程序中创建的所有条目,但忽略了通过 DataGrip 创建的所有条目。 似乎与组合主键有关
【讨论】:
以上是关于ResultSet.next 始终为 false,表格已填充的主要内容,如果未能解决你的问题,请参考以下文章
jdbc如何判断记录集是否为空?用啥方法?ResultSet本身是否根本就没有这样的方法?