Java 为什么我无法读取ResultSet中的下一行
我有一个问题,我试图读取我的结果集中的另一行,但不知道为什么我的循环不能在rs.next结束。是的,我在tblPracownicy中有超过1行。在执行之前,我用whilers.nextsystem.out.printlnrs.getRow1检查结果集内容,结果看起来不错,我得到的结果数和我在tblPracownicy中得到的行数一样多。但在DO循环中,我不知道为什么它不会循环循环。代码如下:Java 为什么我无法读取ResultSet中的下一行,java,sqlite,resultset,executequery,Java,Sqlite,Resultset,Executequery,我有一个问题,我试图读取我的结果集中的另一行,但不知道为什么我的循环不能在rs.next结束。是的,我在tblPracownicy中有超过1行。在执行之前,我用whilers.nextsystem.out.printlnrs.getRow1检查结果集内容,结果看起来不错,我得到的结果数和我在tblPracownicy中得到的行数一样多。但在DO循环中,我不知道为什么它不会循环循环。代码如下: ResultSet rs2 = stat.executeQuery("select _id, cykl_
ResultSet rs2 = stat.executeQuery("select _id, cykl_id, CyklDzien, CyklData, DataZatrudnienia, DataZwolnienia from tblPracownicy");
//wygeneruj harmonogramy dla pracowników
long prac_id = rs2.getLong(1);
int offset;
Cykl cykl = null;
do
{ //pracownicy
//odnajdź i pobierz cykl dla pracownika prac_id
if (cykl == null || cykl.cykl_id != rs2.getLong(2))
for (Cykl c : cykle)
if (c.cykl_id == rs2.getLong(2))
{
cykl = c;
break;
}
//ustaw offset cyklu na dzień 1.szy
GregorianCalendar gc_cykl = new GregorianCalendar();
gc_cykl.setTime(rs2.getDate(4));
gc_harm = new GregorianCalendar(rok, miesiac-1, 1);
//uwzględnij startowy dzień cyklu = CyklDzien
gc_cykl.add(GregorianCalendar.DAY_OF_MONTH, -rs2.getInt(3)+1);
offset = (int) ((gc_harm.getTimeInMillis() - gc_cykl.getTimeInMillis()) / (3600000*24)) % cykl.dlugosc;
//przelicz offset na dodatni
if (offset < 0) offset = cykl.dlugosc + offset;
GregorianCalendar gc_zatr = new GregorianCalendar(new Integer(rs2.getString(5).substring(0, 4)), new Integer(rs2.getString(5).substring(5, 7)), new Integer(rs2.getString(5).substring(8)));
GregorianCalendar gc_zwol = null;
//if (!(rs2.getString(6) == null || rs2.getString(6).equals("")))
if ((rs2.getString(6) != null && !rs2.getString(6).equals("")))
{
gc_zwol = new GregorianCalendar(new Integer(rs2.getString(6).substring(0, 4)), new Integer(rs2.getString(6).substring(5, 7)), new Integer(rs2.getString(6).substring(8)));
}
//definiuj zmiany pracownika na cały miesiąc
for (int dzien=1; dzien <= max; dzien++)
{ //dni
//w dni miesiąca kiedy pracownik nie jest zatrudniony wstawić dni wolne
gc_harm.set(rok, miesiac, dzien);
if (gc_harm.before(gc_zatr) || (gc_zwol != null && gc_harm.after(gc_zwol))) //jesli przed zatrudnieniem lub po zwolnieniu
{ //wpisz dzien wolny = niekasowalne godziny 'xx - xx' o id = 0
stat.executeUpdate("insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + 0 + ");");
}else{
//wpisz zmianę
stat.executeUpdate("insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + cykl.godziny[offset] + ");");
}
offset++;
if (offset >= cykl.dlugosc) offset = 0;
}
}while (rs2.next());
你应该使用正常的while循环,而不是do。。。而一个
如果你使用do。。。循环时,首先执行循环体,然后检查条件。如果您没有从数据库中得到任何结果,则将失败
请记住,ResultSet.next调用不仅仅是检查条件。它实际上使光标向前移动。类似于Iterator.next的工作方式
因此,在执行do块的第一次迭代中,光标指向它尚未前进的任何地方,因为您尚未调用它上的下一个光标,这会导致您看到的行为。确定问题已解决,两个查询会干扰ResultSet的工作
if (gc_harm.before(gc_zatr) || (gc_zwol != null && gc_harm.after(gc_zwol))) //jesli przed zatrudnieniem lub po zwolnieniu
{ //wpisz dzien wolny = niekasowalne godziny 'xx - xx' o id = 0
stat.executeUpdate("insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + 0 + ");");
}else{
//wpisz zmianę
stat.executeUpdate("insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + cykl.godziny[offset] + ");");
}
现在我得到了:
if (gc_harm.before(gc_zatr) || (gc_zwol != null && gc_harm.after(gc_zwol))) //jesli przed zatrudnieniem lub po zwolnieniu
{ //wpisz dzien wolny = niekasowalne godziny 'xx - xx' o id = 0
listaZapytan[x++] = "insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + 0 + ");";
System.out.println(listaZapytan[x-1]);
}else{
//wpisz zmianę
listaZapytan[x++] = "insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + cykl.godziny[offset] + ");";
System.out.println("cykl.godziny[" + offset + "] = " + cykl.godziny[offset]);
System.out.println(listaZapytan[x-1]);
做某事的最大缺点。。它至少执行一次,在你的例子中,它尝试读取最后一条记录的下一条记录…好的,之前我得到了while,我从第二个元素开始循环,得到了相同的问题,我正在尝试先做rs.beforeFirst,但出现错误。结果集为键入\u FORWARD\u ONLY soo我已更改为执行..while.请确保您调用rs.next的唯一时间在whilers.next行内。人们通常倾向于做类似System.out.PrintlHas next?+rs.next;调试时,这实际上会产生问题!kornero-在第二个循环中,loop rs courser设置在最后一个记录之后,这就是为什么循环结束,但我不知道为什么它在应该进入下一个记录时获得最后一个@是的,我知道,你能告诉我到底出了什么问题吗?你说的不循环是什么意思?
if (gc_harm.before(gc_zatr) || (gc_zwol != null && gc_harm.after(gc_zwol))) //jesli przed zatrudnieniem lub po zwolnieniu
{ //wpisz dzien wolny = niekasowalne godziny 'xx - xx' o id = 0
listaZapytan[x++] = "insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + 0 + ");";
System.out.println(listaZapytan[x-1]);
}else{
//wpisz zmianę
listaZapytan[x++] = "insert into tblZmiany (Harmonogram_id, dzien, pracownik_id, godziny_id) "
+ "values (" + id + ", " + dzien + ", " + prac_id + ", " + cykl.godziny[offset] + ");";
System.out.println("cykl.godziny[" + offset + "] = " + cykl.godziny[offset]);
System.out.println(listaZapytan[x-1]);