Java SQLException:结果集关闭后不允许操作
我正在尝试执行getPendingSalesOrderId()方法,该方法调用方法selectInAsending(…) 但这显示了一个SQLException语句 java.sql.SQLException:结果集关闭后不允许操作 这里db.endSelect()将关闭所有连接。我认为问题在于此。Java SQLException:结果集关闭后不允许操作,java,exception,jdbc,Java,Exception,Jdbc,我正在尝试执行getPendingSalesOrderId()方法,该方法调用方法selectInAsending(…) 但这显示了一个SQLException语句 java.sql.SQLException:结果集关闭后不允许操作 这里db.endSelect()将关闭所有连接。我认为问题在于此。 public ArrayList getPendingSalesOrderIDs() { ArrayList a = new ArrayList(); try {
public ArrayList getPendingSalesOrderIDs() {
ArrayList a = new ArrayList();
try {
//ResultSet r = znAlSalesOrder.select("sono", "");
ResultSet r = salesOrder.selectInAsending("soNo", "productionStatus = 'pending' and formatID='Zn-Al'", "soNo");
r.beforeFirst();
while (r.next()) {
a.add(r.getString(1));
}
} catch (SQLException ex) {
}
return a;
}
public ResultSet selectInAsending(String fields,String selection, String orderField)
{
db = new Database();
db.select("SELECT "+fields+" FROM "+name+" WHERE "+selection + " ORDER BY " +orderField+ " ASC");
this.rs=db.rs;
db.endSelect();
return this.rs;
}
public void select(String query)
{
if(con!=null)
{
try {
System.out.println(query);
rs = stm.executeQuery(query);
} catch (SQLException ex) {
Logger.getLogger(Database.class.getName()).log(Level.SEVERE, null, ex);
}
}
}
是的,问题在于
db.endSelect()
调用。
只需返回结果集,然后确保完成后调用rs.close()
。这将负责清理工作。如果db.endSelect()
关闭您的结果集,为什么不删除它(在selectInAsending()
方法中)
您可以在getPendingSalesOrderId()
方法中关闭结果集,如下所示:
ResultSet r = null;
try {
ResultSet r = salesOrder.selectInAsending("soNo", "productionStatus = 'pending' and formatID='Zn-Al'", "soNo");
} catch (SQLException e) {
} finally {
if (r != null) {
try {
r.close();
} catch (SQLException e) {
}
}
}
下面的答案是正确的,我建议您仔细阅读连接、语句和结果集,并了解打开和关闭它们的常见模式,特别是在异常情况下(例如引发异常时)