int i = 0;
while (i < size) {
    String s = username[i];

    String sql4 = "select books1,books2 from " + uname + "a," + s + "b where " + uname + "a.books1=" + s + "b.books2";
    ResultSet rs3 = con.createStatement().executeQuery(sql4);

    System.out.println(sql4);
    while (rs3.next()) {

        count = rs3.getRow();
    }
    i++;
    System.out.println(count);


运行此代码后,输出应为2,1,0,0
但是输出是2,2,2,2。这是i=0的sql查询

最佳答案

使用ResultSet.last()代替while循环。请参见以下示例。

count = rs3.last() ? rs3.getRow() : 0;


坏习惯

此外,您的代码似乎是错误的陈述。您正在循环内执行查询,这会使您的程序性能变差。您可以使用使用COUNTJOIN和其他技术的SQL查询,以更少的代码轻松高效地获取输出。

08-16 18:27