从结果集中提取时出错

时间:2015-10-04 11:20:12

标签: java mysql jdbc resultset

我正在尝试从mysql表中获取数据。当我在phpmyadmin上手动运行时,我的查询返回一个值,但是当我从Java代码运行时,它会给出一个空集。这是查询:

SELECT real_name
from doctorlogin
where password='1234' and id='X11111X';

代码:

public ArrayList<ArrayList<String>> query(String statement) throws SQLException {
    ResultSet rs = stmt.executeQuery(statement);
    int numcols = rs.getMetaData().getColumnCount();
    ArrayList<ArrayList<String>> result = new ArrayList<ArrayList<String>>();
    if (rs.isBeforeFirst()) {
        do {
            ArrayList<String> row = new ArrayList<String>(); // new list per row
            int i = 0;
            while (i <= numcols) {  // don't skip the last column, use <=
                row.add(rs.getString(i++));
            }
            result.add(row); // add it to the result
        } while (rs.next());
    }

    return result;
}

public String login(String username, String password, String domain) throws SQLException {
    String query = "SELECT real_name from " + domain + "login where password='" + password + "' and id='" + username + "';";
    System.out.println(query);
    ArrayList<ArrayList<String>> r = query(query);

    if (r.size() > 1 || r.size() == 0)
        return "Login Failed";
    else
        return r.get(0).get(0);
}

进行编辑后,即使我在phpmyadmin中输入一行,代码仍然无法获取任何结果。

public ArrayList<ArrayList<String>> query(String statement) throws SQLException {
    ResultSet rs = stmt.executeQuery(statement);
    int numcols = rs.getMetaData().getColumnCount();
    ArrayList<ArrayList<String>> result = new ArrayList<ArrayList<String>>();
    while ( rs.next() ) {
        ArrayList<String> row = new ArrayList<String>(); // new list per row
        for ( int i = 1; i <= numcols; i++ ) {
            row.add(rs.getString(i));
        }
        result.add(row); // add it to the result
    }
    return result;
}

phpmyadmin上查询的屏幕截图 - &gt; https://drive.google.com/drive/folders/0B_yqoCAAV2rFdDZqUzlmeXljNWs

2 个答案:

答案 0 :(得分:2)

在调用rs.next()之前,您无法从行中检索信息。所以ResultSet循环的通常格式就是

while (rs.next()) {
    // Retrieve the column values
}

那里不需要if声明。如果没有返回的行,if为false,您将返回一个空列表。但对于上面的简单while也是如此。不需要do...while() - 您首先需要移动光标,然后才能读取值。

最后,列的索引是从1开始,而不是从0开始。因此,i应该从1开始。但是为什么不用for循环而不是while替换它?< / p>

while ( rs.next() ) {
     ArrayList<String> row = new ArrayList<String>(); // new list per row
     for ( int i = 1; i <= numcols; i++ ) {
         row.add(rs.getString(i));
     }
     result.add(row); // add it to the result
}

您应该阅读ResultSet documentation,因为信息就在那里。

答案 1 :(得分:0)

row.add(rs.getString(i++));

应改为

row.add(rs.getString(++i));

因为行0无法访问。行计数从1开始。

在第二个代码中,在从DB获取对象之前会递增,因此第一个值为1