java 批量插入10万条数据

for (int i = 0; i < 100000; i++) {
                dbHelper.insert("INSERT aaa(name)  Values ('1')");
            }

运行时间==780450ms

conn = getConn();
// JAVA默认为TRUE,我们自己处理需要设置为FALSE,并且修改为手动提交,才可以调用rollback()函数
conn.setAutoCommit(false);
st = conn.createStatement();
long start = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
    st.execute("INSERT bbb(name)  Values ('1')");
}
// 事务提交
conn.commit();
long end = System.currentTimeMillis();
System.out.println("运行时间==" + (end - start) + "ms");

运行时间==21484ms

conn = getConn();
// JAVA默认为TRUE,我们自己处理需要设置为FALSE,并且修改为手动提交,才可以调用rollback()函数
conn.setAutoCommit(false);
st = conn.createStatement();
long start = System.currentTimeMillis();
for (int i = 0; i < 100000; i++) {
    st.addBatch("INSERT ccc(name)  Values ('1')");
}
st.executeBatch();
// 事务提交
conn.commit();

运行时间==21524ms

在mysql链接后加上如下参数,代码和上面的完全相同,结果速度快了很多

&rewriteBatchedStatements=true

运行时间==8216ms

而我在第二种方法的连接上加上&rewriteBatchedStatements=true,结果运行结果和原来相差无几

运行时间==21538ms

参考链接:

介绍MySQL Jdbc驱动的rewriteBatchedStatements参数

转载于:https://www.cnblogs.com/foreverstudent/p/3893274.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值