java从MySQL表中取出数据时报错:java.sql.SQLException: Before start of result set

本文通过一个具体的Java代码示例,详细解析了在使用PreparedStatement执行SQL查询并处理ResultSet时遇到的“Before start of resultset”异常。文章展示了如何正确地使用next()方法来定位结果集中的第一条记录,并给出了修正后的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境:

java 1.8, MySQL 5.7

问题:

for(String each:book.getLabel()){
                ps = cn.prepareStatement("SELECT labelid FROM booklabel WHERE label=?");
                ps.setString(1, each);
                rs = ps.executeQuery();
                if(rs.next()){ // if label has been in booklabel DB, get its labelid
                    labelIDSet.add(rs.getString(1));
                }else{ // if not,store it into booklabel DB and then get its labelid
                    //store
                    ps = cn.prepareStatement("INSERT INTO booklabel(label) " + "VALUES(?)");
                    ps.setString(1, each);
                    ps.executeUpdate();
                    //get labelid
                    ps = cn.prepareStatement("SELECT labelid FROM booklabel WHERE label=?");
                    ps.setString(1, each);
                    rs = ps.executeQuery();
                    // create labelIDSet

                    String result = rs.getString(1);
                    labelIDSet.add(result);


                }
            }

String result = rs.getString(1);这里报了个错:

java.sql.SQLException: Before start of result set

原因:

因为在取出ResultSet对象,对其进行操作时,没有采用.next()方法将ResultSet对象的光标移至指定行,不管Statement对象执行SQL语句是否十分确定能搜出记录


解决:

for(String each:book.getLabel()){
                ps = cn.prepareStatement("SELECT labelid FROM booklabel WHERE label=?");
                ps.setString(1, each);
                rs = ps.executeQuery();
                if(rs.next()){ // if label has been in booklabel DB, get its labelid
                    labelIDSet.add(rs.getString(1));
                }else{ // if not,store it into booklabel DB and then get its labelid
                    //store
                    ps = cn.prepareStatement("INSERT INTO booklabel(label) " + "VALUES(?)");
                    ps.setString(1, each);
                    ps.executeUpdate();
                    //get labelid
                    ps = cn.prepareStatement("SELECT labelid FROM booklabel WHERE label=?");
                    ps.setString(1, each);
                    rs = ps.executeQuery();
                    // create labelIDSet
                    if(rs.next()){
                        String result = rs.getString(1);
                        labelIDSet.add(result);
                    }

                }
            }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值