huaeryushao 2019-04-26 10:00 采纳率: 0%
浏览 4951

运行报Operation not allowed after ResultSet closed错误

try {
long a = System.currentTimeMillis();
con = JdbcUtils_C3P0.getConnection();
String sql = "Select * from al1688shopmessageurl01 where num ";
ps = con.prepareStatement(sql);
rs = ps.executeQuery();
int row = rs.getRow();
while (rs.next()) {
if (row % 100 == 0) {
StringBuffer str = new StringBuffer(
"insert into ali_goods_basic_info(UUID,NAME,URL,COMPANY_NAME,KEYWORD) values");

                str.append("('" + rs.getString("uuid") + "'," + "'" + rs.getString("title") + "'," + "'"
                        + rs.getString("url") + "'," + "'" + rs.getString("name") + "'," + "'"
                        + rs.getString("keywords") + "')");
                ps.executeUpdate(str.toString());
                //con.commit();
                System.out.println("ok");

            }

        }

        if (rs != null) {
            rs.close();
        }
        if (ps != null) {
            ps.close();
        }
        if (con != null) {
            con.close();
        }
        System.out.println("插入操作完成");
        System.out.println("\r<br>执行耗时 : " + (System.currentTimeMillis() - a) / 1000f + " 秒 ");
    } catch (SQLException e) {
        e.printStackTrace();
    }
  • 写回答

2条回答 默认 最新

  • threenewbee 2019-04-26 10:09
    关注

    ps.executeUpdate(str.toString());
    一个ps多个rs进行操作.
    不能互相交替使用,会引起rs已经关闭错误.
    你可以用两个独立的ps对象

    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)