检查Java中的ResultSet是否为空

原学程将引见检讨Java中的ResultSet能否为空的处置办法,这篇学程是从其余处所瞅到的,而后减了1些海外法式员的疑问与解问,愿望能对于您有所赞助,佳了,上面开端进修吧。

检查Java中的ResultSet是否为空 教程 第1张

成绩描写

我在法式中应用HSQLDB。我想检讨我的成果散能否为空。

//check if empty first
if(results.next() == false){
System.out.println("empty");
}

//display results
while (results.next()) {
String data = results.getString("first_name");
//name.setText(data);
System.out.println(data);
}

上述办法不克不及正常任务。依据这个post,我必需挪用.first()或者.beforeFirst()将游标逗留在第1言,但是HSQL没有支撑.first()以及.beforFirst()。我也测验考试添减connection.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
但是我依然获得雷同的成果(我获得的新闻是空的,数据去自数据库!)
我在这里做错了甚么?

推举谜底

假如我懂得您的目的,您不妨应用do while轮回

if (!results.next()) {
  System.out.println("empty");
} else {
  //display results
  do {
 String data = results.getString("first_name");
 //name.setText(data);
 System.out.println(data);
  } while (results.next());
}

或许,您不妨像如许保存count

int count = 0;
//display results
while (results.next()) {
  String data = results.getString("first_name");
  //name.setText(data);
  System.out.println(data);
  count++;
}
if (count < 一) {
  // Didn't even read one row
}

佳了闭于检讨Java中的ResultSet能否为空的学程便到这里便停止了,愿望趣模板源码网找到的这篇技巧文章能赞助到年夜野,更多技巧学程不妨在站内搜刮。