从数据库检索数据时,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();
}
%>
沙扎德

您需要为选项检索查询使用单独的语句。根据声明文档

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

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

嵌套 Do While 内循环仅在外循环的第一次迭代时运行

嵌套 while 循环以及如何在第一次运行后访问内部循环

While 循环在第一次迭代后停止

While 循环在第一次迭代后中断

为什么While(rs.next())语句在第一次迭代后结束?

嵌套循环的第一个 while 循环只迭代一次

FPDF中的while循环仅第一次检索数据。它以pdf格式完美打印表格,但第一次输入后不输入检索到的数据

第一次迭代后嵌套 for 循环未在 python 中运行

使用数据库值嵌套在 php while 循环中

迭代嵌套的Firebase数据库节点时出现DatabaseException

Ajax 在第一次提交时不起作用,页面刷新后只有结果才会刷新

目标== list [mid]时,while循环的第一次迭代中二进制搜索未返回true

选择进入while循环时更新sqlite数据库

循环 8 次时嵌套 For 循环不起作用

for循环仅在第一次迭代时执行

以下程序是否在外循环的第一次迭代中执行嵌套循环?

jQuery 在第一次点击时不起作用

反应:动态位置在第一次渲染时不起作用

Viewflipper动画在第一次滑动时不起作用

“反应”单选按钮在第一次单击时不起作用

javascript切换在第一次按下时不起作用

html Javascript提交按钮在第一次单击时不起作用

onClick 事件在第一次点击时不起作用

第一次单击MaterialUI FormControl API TextField时onClick不起作用

react-simple-image-slider 在第一次渲染时不起作用

插值在第一次加载页面时不起作用

jQuery在第一次打开页面时不起作用

Focusout 事件在输入事件 jQuery 中的第一次激活时不起作用

JQuery 在第一次点击时不起作用,但在它之后工作