mysql批量插入更新加参数rewriteBatchedStatements

测试环境:mysql-connector-java-5.1.34.jar ;
jdbc:mysql://192.168.21.103:3306/yzhs?rewriteBatchedStatements=true
测试代码
1、不使用jdbc的addBatch\executeBatch

int size=100000;
    private void noBatch(){
        JDBCHelper jdbc=JDBCHelper.getInstance();
        Connection conn=jdbc.getConnection();
        try {
            conn.setAutoCommit(false);    
            PreparedStatement prep=conn.prepareStatement("insert into temp_ban_list() values(?)");
            long a=System.currentTimeMillis();  
            for (int i = 0; i < size; i++) {
                prep.setInt(1, i);
                prep.execute(); 
            }
            conn.commit();
            long b=System.currentTimeMillis(); 
            System.out.println("MySql非批量插入10万条记录用时"+ (b-a)+" ms");  
        } catch (SQLException e) {
            e.printStackTrace();
        }

    }
    /*
     * 结果
     * MySql非批量插入10万条记录用时51657 ms
     * MySql非批量插入10万条记录用时49765 ms
     */

2、使用jdbc的addBatch\executeBatch

private void batch(){
        JDBCHelper jdbc=JDBCHelper.getInstance();
        Connection conn=jdbc.getConnection();
        try {
            conn.setAutoCommit(false);    
            PreparedStatement prep=conn.prepareStatement("insert into temp_ban_list() values(?)");
            long a=System.currentTimeMillis();  
            for (int i = 0; i < size; i++) {
                prep.setInt(1, i);
                prep.addBatch();
            }
            prep.executeBatch();
            conn.commit();
            long b=System.currentTimeMillis(); 
            System.out.println("MySql批量插入10万条记录用时"+ (b-a)+" ms");  
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    /*
     * 结果
     * MySql批量插入10万条记录用时1040 ms
     * MySql批量插入10万条记录用时1097 ms
     * 
     * 去掉参数,结果
     * MySql批量插入10万条记录用时91629 ms
     */

结论:使用jdbc的addBatch\executeBatch时url要加参数rewriteBatchedStatements=true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值