日期:2014-05-18  浏览次数:20683 次

无法从数据库循环读出下一条记录
如题,只能读出一条记录,代码如下:

public   synchronized   ArrayList   getOkFile(String   SEQUENCE)   {
       
String   sql   =   "SELECT     T_SIG_INFO.FLOW_ID   AS   ID   FROM   T_SIG_PROCESS,T_SIG_INFO   where   T_SIG_PROCESS.FLOW_ID=T_SIG_INFO.FLOW_ID   AND   T_SIG_INFO.SIGNOK_NUM=T_SIG_INFO.SIG_NUM   AND   T_SIG_PROCESS.SEQUENCE= ' "
+SEQUENCE+ " 'AND   T_SIG_PROCESS.IS_ACCEPT= '0 ' ";
ResultSet   rs1=null;
ResultSet   rs2=null;
ArrayList   alRet   =   new   ArrayList();
String   FLOW_ID;
try   {
openConnection();
openStatement();
rs1   =   query(sql);
if(rs1   !=   null){
while(rs1.next()){//问题所在:此处循环只能一次
FLOW_ID=rs1.getString( "ID ");  
Sig_InfoModel   m   =   new   Sig_InfoModel();

sql   =   "SELECT   BUILDER,FILE_NAME,TO_CHAR(SIG_BEGIN, 'yyyy-mm-dd   hh24:mi ')   AS   SIG_BEGIN   FROM   T_SIG_INFO   where   FLOW_ID= ' "+FLOW_ID+ " ' ";
try   {
rs2   =   query(sql);
if   (rs2   !=   null)   {
if(rs2.next())   {
m.setFlow_builder(rs2.getString( "BUILDER "));
m.setFile_name(rs2.getString( "FILE_NAME "));
m.setSig_begin(rs2.getString( "SIG_BEGIN "));
m.setFlow_id(FLOW_ID);
alRet.add(m);
}
}
}   catch   (Exception   ex)   {
ex.printStackTrace();
return   null;
}
}
return   alRet;
}
}   catch   (Exception   ex)   {
ex.printStackTrace();
return   null;
}

finally   {
try   {
if   (rs2!=   null)
rs2.close();
if   (rs1!=   null)
rs1.close();
}   catch   (SQLException   ig)   {
}
closeStatement();
closeConnection();
}
return   null;


}
}

------解决方案--------------------
你这样是不行的。
你打开了两次resultset。这是不允许的。
调用rs2 = query(sql)时就把rs1给close了。
再从rs1里取数据时就取不到了