改正代码。 while (rs.next()) { count++; } Object[][] info = new Object[count][6]; String[] title = { "学号", "姓名", "出生日期", "性别", "专业", "宿舍楼" }; count = 0; while (rs.next()) { info[count][0] = rs.getString("sno"); info[count][1] = rs.getString("sname"); info[count][2] = rs.getString("sbirth"); info[count][3] = rs.getString("ssex"); info[count][4] = rs.getString("sclass"); info[count][5] = rs.getString("saddress"); count++; }
时间: 2024-03-01 07:54:06 浏览: 92
可以将第二个 while 循环中的代码合并到第一个 while 循环中,如下所示:
```
while (rs.next()) {
count++;
}
Object[][] info = new Object[count][6];
String[] title = { "学号", "姓名", "出生日期", "性别", "专业", "宿舍楼" };
count = 0;
rs.beforeFirst(); // 将结果集的指针重置到第一行之前
while (rs.next()) {
info[count][0] = rs.getString("sno");
info[count][1] = rs.getString("sname");
info[count][2] = rs.getString("sbirth");
info[count][3] = rs.getString("ssex");
info[count][4] = rs.getString("sclass");
info[count][5] = rs.getString("saddress");
count++;
}
```
这样就可以正确地将 ResultSet 中的数据保存到 info 数组中了。需要注意的是,第二个 while 循环中的代码执行之前,需要将 ResultSet 的指针重置到第一行之前,否则第二个 while 循环也无法遍历 ResultSet 中的数据。
相关问题
检查以下代码。while (rs.next()) { count++; } Object[][] info = new Object[count][6]; String[] title = { "学号", "姓名", "出生日期", "性别", "专业", "宿舍楼" }; count = 0; while (rs.next()) { info[count][0] = rs.getString("sno"); info[count][1] = rs.getString("sname"); info[count][2] = rs.getString("sbirth"); info[count][3] = rs.getString("ssex"); info[count][4] = rs.getString("sclass"); info[count][5] = rs.getString("saddress"); count++; } JTable table = new JTable(info, title); contentPane.add(new JScrollPane(table), BorderLayout.CENTER); validate();
这段代码的问题在于第二个 while 循环,因为在第一个 while 循环中已经遍历了 ResultSet 中的所有数据行,所以在第二个 while 循环中 rs.next() 不会再返回任何数据行,导致 info 数组中的数据全部为 null。
为了解决这个问题,可以将第二个 while 循环中的代码合并到第一个 while 循环中,如下所示:
```
while (rs.next()) {
count++;
info[count-1][0] = rs.getString("sno");
info[count-1][1] = rs.getString("sname");
info[count-1][2] = rs.getString("sbirth");
info[count-1][3] = rs.getString("ssex");
info[count-1][4] = rs.getString("sclass");
info[count-1][5] = rs.getString("saddress");
}
```
这样就可以正确地将 ResultSet 中的数据保存到 info 数组中了。
改正程序。 con = DriverManager.getConnection(url, user, pwd); sql = con.createStatement(); String sqlStatement; sqlStatement = "SELECT * FROM student"; PreparedStatement pstm = con.prepareStatement(sqlStatement); rs = sql.executeQuery(sqlStatement); int count =0; while(rs.next()) { count++; } rs = sql.executeQuery(sqlStatement); Object[][] info=new Object[count][6]; String []title= {"学号","姓名","出生日期","性别","专业","宿舍楼"}; count=0; while(rs.next()) { info[count][0]=rs.getString("sno"); info[count][1]=rs.getString("sname"); info[count][2]=rs.getString("sbirth"); info[count][3]=rs.getString("ssex"); info[count][4]=rs.getString("sclass"); info[count][5]=rs.getString("saddress"); count++; }
改正后的程序如下:
```
con = DriverManager.getConnection(url, user, pwd);
String sqlStatement;
sqlStatement = "SELECT * FROM student";
PreparedStatement pstm = con.prepareStatement(sqlStatement);
rs = pstm.executeQuery();
int count = 0;
while(rs.next()) {
count++;
}
rs.beforeFirst();
Object[][] info = new Object[count][6];
String[] title = {"学号", "姓名", "出生日期", "性别", "专业", "宿舍楼"};
count = 0;
while(rs.next()) {
info[count][0] = rs.getString("sno");
info[count][1] = rs.getString("sname");
info[count][2] = rs.getString("sbirth");
info[count][3] = rs.getString("ssex");
info[count][4] = rs.getString("sclass");
info[count][5] = rs.getString("saddress");
count++;
}
```
修改的内容如下:
1. 将原来的 `sql` 对象改为 `pstm` 对象,并使用 `executeQuery()` 方法执行查询语句。
2. 在第一个 `while` 循环中统计查询结果的行数,并使用 `beforeFirst()` 方法将结果集指针返回到第一行。
3. 在第二个 `while` 循环中遍历查询结果,并将每行数据存储到 `info` 数组中。
阅读全文