java - 为什么我无法读取 ResultSet 中的下一行

标签 java sqlite resultset executequery

我有一个问题,我正在尝试读取我的 ResultSet 中的另一行,但不知道为什么我的循环不能在 rs.next() 处结束。是的,我在 tblPracownicy 中有超过 1 行。我在 DO 之前用 while(rs.next())system.out.println(rs.getRow(1)) 检查 ResultSet 内容,它看起来不错,我得到的结果数量与我在 tblPracownicy 中得到的行一样多。但是在 DO 循环中我不知道为什么它不会循环循环。这是代码:

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 ... while 循环。

while(rs2.next()) {
    // do your stuff
}

如果您使用 do ... while 循环,循环体会先执行,然后再检查条件。如果您没有从数据库返回任何结果,这将失败。

请记住,ResultSet.next() 调用不仅会检查条件。它实际上使光标前进。类似于 Iterator.next() 的工作方式。

因此,在 do block 执行时的第一次迭代中,光标指向任何地方(它还没有前进,因为您还没有调用 next() 在它上面)导致你看到的行为。

关于java - 为什么我无法读取 ResultSet 中的下一行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9260387/

相关文章:

java - 数组对象和最大值

Java - MyBatis - 一次处理一条记录

java - MyBatis。选择错误

java - GWT:如何避免使用 i18n 常量指定默认属性文件

java - 让 PDF 显示在 HTML 中,而不是使用 Adob​​e 加载或加载到单独的窗口中

android - 在sqlite数据库android中插入日期时间

java - (Android) Java 从 SQLDatabase 获取值

java - 多线程环境下ResultSet成员变量的复用

java - 良好的软件实践 - 获取和设置方法

sqlite - 我如何将 CakePHP 连接到 SQLite 数据库?