微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从数据库检索数据时,next() 的嵌套 while 循环在第一次迭代后不起作用

如何解决从数据库检索数据时,next() 的嵌套 while 循环在第一次迭代后不起作用

我正要从 questionsDB 和 optionsDB 中显示问题及其各自的选项。 我创建了两个结果集和两个查询来在嵌套循环中执行这些操作。通过显示一个问题及其各自的选项,它在第一次迭代中工作正常,但之后不迭代数据。

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<%@page import="java.sql.*"%>

<%
String driverName = "com.MysqL.jdbc.Driver";
String connectionUrl = "jdbc:MysqL://localhost:3306/";
String dbname = "onlineFeedback";
String userId = "root";
String password = "123456";

try {
    Class.forName(driverName);
} catch (ClassNotFoundException e) {
    e.printstacktrace();
}

Connection connection = null;
Statement statement = null;
ResultSet resultQuestions = null;
ResultSet resultOptions = null;

try{ 
    connection = DriverManager.getConnection(connectionUrl+dbname,userId,password);
    statement=connection.createStatement();
    String qsql ="SELECT * FROM questionsDB";

    resultQuestions = statement.executeQuery(qsql);
    
    while(resultQuestions.next()) {
        int curQuestion= Integer.parseInt(resultQuestions.getString("qid"));
%>

<%= resultQuestions.getString("qid") %>
<%=resultQuestions.getString("questionmessage") %>
<% 
String osql ="SELECT * FROM optionsDB WHERE qid="+curQuestion;
resultOptions = statement.executeQuery(osql); 
%>

<%      while(resultOptions.next()) {
%>
            <%=resultOptions.getString("optionmessage") %>
<%  
        }
    }
//connection.close();
} 
catch (Exception e) {
    e.printstacktrace();
}
%>

解决方法

您需要为选项检索查询使用单独的语句。根据{{​​3}}:

默认情况下,每个 Statement 对象只能打开一个 ResultSet 对象 同时。因此,如果读取一个 ResultSet 对象是 与另一个的阅读交错,每个都必须已经生成 由不同的 Statement 对象。 Statement中的所有执行方法 接口隐式关闭语句的当前 ResultSet 对象 如果存在开放的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。