admin
管理员
管理员
  • UID1
  • 粉丝1
  • 关注0
  • 发帖数378
  • 社区居民
  • 忠实会员
  • 原创写手
阅读:1211回复:0

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

楼主#
更多 发布于:2016-03-04 19:59
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;
}

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


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

 

 

 

 

 

 

 

异常中心网是一家专门收集整理程序员编程过程中遇到的常见异常(exception)以及各种异常问答中心的网站。异常中心网旨在,减少程序员在编码遇到异常,处理各种异常时间和痛苦,让程序员能更愉快的、快速的定位异常并查找对应的异常解决方案。异常中心网诚心打造最完美的编程社区为程序员用户服务,努力成为最好的程序员乐园程序员社区程序异常中心程序bug中心异常问答中心

 

喜欢0 评分0
游客

返回顶部