java - 从数据库中检索数据时,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 对象的读取与另一个 ResultSet 对象的读取交错,则每个对象都必须由不同的 Statement 对象生成。Statement 接口中的所有执行方法都会隐式关闭语句的当前 ResultSet 对象(如果存在打开的对象)。
推荐阅读
- ios - 打开 Health 并通过 URL Scheme 进入 App 的权限
- apache - Symfony 3.4 Apache Permission WebServer unable to write file in folder non writable
- git - Why does git rebase with no arguments work the way that it does?
- c++ - C++/OpenSSL 将 PEM 加载到 STACK_OF(X509)
- reactjs - 传递给解析器不是有效的 GraphQL DocumentNode。您可能需要使用“graphql-tag”或其他方法将您的操作转换为文档
- ms-access - 访问子报表比较记录
- c# - 使用 AjaxToolKit:PopUpExtender 在 asp.net Web 应用程序中没有出现弹出窗口
- node.js - 无法在 Windows 上使用 nvm 安装节点
- mysql - 数据库设计布局
- reactjs - 将值从灯箱传递给父母