hjw1197052444 2016-03-04 11:34 采纳率: 75%
浏览 2362
已采纳

java JDBC 批量插入的时候报数组下标越界,求大神

代码:
private static Boolean Function_User(Map resultMap, String sql,String tableType) {
// TODO Auto-generated method stub

    Connection conn=null;
    PreparedStatement insert_st=null;
    int count = 0;
    final int batchSize = 500;
    System.out.println("开始:"+Calendar.getInstance().getTime());
    try {
        conn=DriverManager.getConnection(db_url,db_name,db_pwd);
        conn.setAutoCommit(false);
        insert_st = conn.prepareStatement(sql);
        for (int i = 0; i < resultMap.get(tableType).size(); i++) {
            Object obj = resultMap.get(tableType).get(i);               
            OrderUserSnap user = (OrderUserSnap) obj;
            insert_st.setString(1, ZH_S(user.getId()));
            insert_st.addBatch();

             if(++count % batchSize == 0) {
                 insert_st.executeBatch();
                 insert_st.clearBatch();
                }
             System.out.println("tt:"+count);
        }
        insert_st.executeBatch();
        insert_st.clearBatch();
    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }finally{
        try {
            insert_st.close();
            conn.close();
             System.out.println("结束:"+Calendar.getInstance().getTime());
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }       
    }
    return true;
}
  • 写回答

3条回答 默认 最新

  • hjw1197052444 2016-03-04 11:42
    关注

    擦 已经解决:原因是 我insert_st.setString(1, ZH_S(user.getId()));,传递的参数过多,Oracle的批处理个数限制为:
    count=传参个数 * 查入的数据条数

    上边设置的1000条数据,进行一次批处理,越界了~
    将 final int batchSize = 500; 的值设小一点就屁事没有

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘