对空结果集的非法操作 - 如何检查它是不是为空? [复制]

Posted

技术标签:

【中文标题】对空结果集的非法操作 - 如何检查它是不是为空? [复制]【英文标题】:Illegal operation on empty result set - how to check if it's empty? [duplicate]对空结果集的非法操作 - 如何检查它是否为空? [复制] 【发布时间】:2013-03-28 21:18:38 【问题描述】:

我的 Java 插件有问题 - 当没有找到结果时,它表示结果集为空。谁能告诉我如何检测结果集是否为空?

String url = "jdbc:mysql://" + host + ":" + port + "/" + database + "";

Connection conn = DriverManager.getConnection(url, username, password);
Statement stmt = conn.createStatement();

ResultSet rs;
String p = pp.getName();
rs = stmt.executeQuery("SELECT * FROM " + table + " WHERE username='"
        + p + "' AND recieved=0 ORDER BY id DESC");
rs = stmt.getResultSet();

【问题讨论】:

究竟是什么问题?您如何使用ResultSet 请参阅:sscce.org 并将您的帖子更新为更易于理解的问题。 这就是我的代码:String url = "jdbc:mysql://" + host + ":" + port + "/" + database + ""; Connection conn = DriverManager.getConnection(url,username,password);语句 stmt = conn.createStatement();结果集rs;字符串 p = pp.getName(); rs = stmt.executeQuery("SELECT * FROM " + table + " WHERE username='" + p + "' AND recieved=0 ORDER BY id DESC"); 然后我这样做是为了得到结果 rs = stmt.getResultSet(); 异常堆栈跟踪准确地告诉了这个异常是在哪里引发的。发布此堆栈跟踪以及相关代码。 【参考方案1】:

标准方法是尝试使用next() 方法获取下一行,并检查它是否返回false(意味着没有下一行,所以它是空的)。像这样:

ResultSet rs;
// run query on database
if (!rs.next()) 
    // no row(s) found from database
 else 
    // row(s) found from database OK

编写一个do...while循环可以很方便:

if (!rs.next()) 
    // handle no rows found
 else 
    // process all rows
    do 
        // process row
     while (rs.next());

【讨论】:

以上是关于对空结果集的非法操作 - 如何检查它是不是为空? [复制]的主要内容,如果未能解决你的问题,请参考以下文章

NodeJS - 如何检查 MySQL 结果是不是未定义/为空?

如何检查结果集是不是为空?

Perl如何检查数组是不是仍然为空?

如何在不使用大型结果集的情况下检查一个字符串是不是是另一个字符串的子字符串?

如何使用火花流检查 rdd 是不是为空?

如何检查参数是不是为空并在查询中检查它