我正在尝试从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
答案 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
。