我怎样才能发现ResultSet
我通过查询数据库得到的 是空的?
问问题
114346 次
6 回答
37
在执行语句之后,您可以立即使用 if 语句。例如
ResultSet rs = statement.execute();
if (!rs.next()){
//ResultSet is empty
}
于 2010-02-25T05:42:31.770 回答
30
这绝对提供了很好的解决方案,
ResultSet rs = stmt.execute("SQL QUERY");
// With the above statement you will not have a null ResultSet 'rs'.
// In case, if any exception occurs then next line of code won't execute.
// So, no problem if I won't check rs as null.
if (rs.next()) {
do {
// Logic to retrieve the data from the resultset.
// eg: rs.getString("abc");
} while(rs.next());
} else {
// No data
}
于 2011-12-06T18:46:37.310 回答
11
使用rs.next()
:
while (rs.next())
{
...
}
如果结果集为空,则循环内的代码不会执行。
于 2010-02-25T04:54:05.813 回答
9
如果你使用 rs.next() 你会移动光标,而不是你应该移动 first() 为什么不直接检查使用 first() ?
public void fetchData(ResultSet res, JTable table) throws SQLException{
ResultSetMetaData metaData = res.getMetaData();
int fieldsCount = metaData.getColumnCount();
for (int i = 1; i <= fieldsCount; i++)
((DefaultTableModel) table.getModel()).addColumn(metaData.getColumnLabel(i));
if (!res.first())
JOptionPane.showMessageDialog(rootPane, "no data!");
else
do {
Vector<Object> v = new Vector<Object>();
for (int i = 1; i <= fieldsCount; i++)
v.addElement(res.getObject(i));
((DefaultTableModel) table.getModel()).addRow(v);
} while (res.next());
res.close();
}
于 2011-06-25T19:05:48.303 回答
5
if (rs == null || !rs.first()) { //空的 } 别的 { //不是空的 }
注意,在这个方法调用之后,如果结果集不为空,则它在开头。
于 2011-07-01T14:09:30.887 回答
4
计算 java.sql.ResultSet 的大小:
int size = 0;
if (rs != null) {
rs.beforeFirst();
rs.last();
size = rs.getRow();
}
(来源)
于 2010-02-25T04:53:59.860 回答