2 hjw1197052444 hjw1197052444 于 2016.03.04 19:34 提问

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
hjw1197052444   2016.03.04 19:42
已采纳

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

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

hjw1197052444
hjw1197052444   2016.03.04 19:36

报错信息:
查询出的数据条数为:1450
开始:Fri Mar 04 19:32:49 CST 2016
tt:1



tt:999
结束:Fri Mar 04 19:32:50 CST 2016
java.lang.ArrayIndexOutOfBoundsException: -32589
at oracle.jdbc.driver.OraclePreparedStatement.setupBindBuffers(OraclePreparedStatement.java:2677)
at oracle.jdbc.driver.OraclePreparedStatement.executeBatch(OraclePreparedStatement.java:9255)
at oracle.jdbc.driver.OracleStatementWrapper.executeBatch(OracleStatementWrapper.java:210)
at Bing.Main.Function_User(Main.java:422)
at Bing.Main.DataForDB(Main.java:156)
at Bing.Main.ForServlet(Main.java:110)
at Bing.Main.access$0(Main.java:63)
at Bing.Main$My_Timer.run(Main.java:58)
at java.util.TimerThread.mainLoop(Timer.java:512)
at java.util.TimerThread.run(Timer.java:462)

hjw1197052444
hjw1197052444   2016.03.04 19:37

当第1000条数据的时候,执行
if(++count % batchSize == 0) {
insert_st.executeBatch();
insert_st.clearBatch();
}
及1000条数据 提交一次,报错,说什么下标越界,找不到原因啊

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
ibatis 批量插入时的越界异常
话说几个月前,就发现了这个异常,第一行提示java.lang.ArrayIndexOutOfBoundsException: -32593 越界,还是负数的,就继续找根源,找到项目中的批量插入,缺发现找不到越界的原因,代码是这种形式的 executor.startBatch(); for (int i = 0, count =
Oracle executeBatch异常:ArrayIndexOutOfBoundsException
原文地址:http://yanwushu.sinaapp.com/oracle_executebatch_arrayindexoutofboundsexception/ 使用jdbc接口PreparedStatement.executeBatch()向oracle中批量执行sql时候,出现异常ArrayIndexOutOfBoundsException,具体信息如下: ja
Java错误提示-------数组下标越界
错误提示:提示出错:Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 2  意思是数组下标越界 //at Array.main(Array.java:30) import java.util.Scanner; public class Array { public
关于jxl读取excel数组越界问题
jxl读取excel是以最大行和列的单元格且这个单元格有数据为数组的长度,比如有数据的最大行和列的单元格为第十行第十列,从第一行和第一列读取excel,10就是数组的长度,超过这个长度,比如读出第十行第十一列,或是第十一行第十列,都为报数组越界异常。
关于Java导入excel表格出现下标越界异常的解决方法(个人心得记录)
最近在做java批量导入时经常出现这个异常,先上图 根据这个数组下标越界异常百度上搜索结果一大堆,但没有适合自己的解决办法,只能是自己慢慢摸索了,不过终于被我找到适合自己的解决办法了,上图 图上画圈的地方是找到excel中有数据的最大列数,但是如果建表格的时候不注意,在超出其他列的地方输入了数据,那么就会报上面的越界异常,解决办法就是上面的画圈部分改成自己要导入的列数就可以了 ,比
ArrayList并发add()可能出现数组下标越界异常 | 10+10<20
ArrayList内部,add()分两步操作,step1检查array容量,step2塞值并将size+1。 假设有2个线程操作同一个ArrayList,且array的容量刚好还可以存一个值。Thread1执行add()的step1后被挂起,这时Thread1“认为”array还有位置可以塞值,然后安心地睡去了;Thread2执行add(),存入一个元素并将size+1,而+1后的size已经大
关于Java中使用split()方法时报ArrayIndexOutOfBoundsException数组越界异常解决方法
分析原因:split是要用正则表达式的,正则表达式中.代表任意字符,用split("\\.")。 [java] view plain copy 今天写了个字符串拼接程序,中间用到了split方法。但在测试的时候。总是报数组越界错误:java.lang.ArrayIndexOutOfBoundsException ;      我写的测试代
maven 打包报数组越界问题
昨晚项目急着上线 突然打包出了问题 使用mvn -X package运行发现是arrayindexoutofbound 11117错误 。好奇怪 怎么会越界呢 因为报的不是我业务代码的错而是maven的架包和依赖里的 所以我确定是加保问题 。尝试了几次添加和移除没用  。今天早上来 我新建了一个工程把另一个工程的pom依赖一个一个的放进新项目里打包尝试 最后确认了是json-lib导致的  我把它
java 数组下标越界异常(ArrayIndexOutOfBoundsException)
java 数组下标越界异常(ArrayIndexOutOfBoundsException) java 数组下标越界异常(ArrayIndexOutOfBoundsException)
ViewPager数组角标越界异常 java.lang.IndexOutOfBoundsException
数量明明是对的,但是还是会报 数组角标越界异常 后来我就设置了 mViewPager.setOffscreenPageLimit(mPhotoList.size()); 一次性加载出来,对于图片少的可以用,图片多的就不行了..