Spring JdbcTemplate批量更新速度很慢的问题

由于一次要执行很多条插入语句(5w),通常通过mysql原生的插入语句会有类似的格式:


insert into TableAAA(f1,f2) values (f11v,f21v),(f12v,f22v)...

执行速度上是没有问题,大概5,6秒。在用JdbcTemplate的时候,就是用batchUpdate方法来写批量执行的语句:

String sql = "insert into code(id,code,status,time) values(?,?,?,?)";
jdbcTemplate.batchUpdate(sql, codes, codes.size(), new ParameterizedPreparedStatementSetter<CouponCode>() {
    @Override
    public void setValues(PreparedStatement preparedStatement, CouponCode code) throws SQLException {
        preparedStatement.setInt(1, code.getCid());
        preparedStatement.setString(2, code.getCode());
        preparedStatement.setInt(3, code.getStatus());
        preparedStatement.setDate(4, new Date(new java.util.Date().getTime()));
    }
});
当执行语句的时候,发现需要十几秒才执行完成,这比原生的sql语句差多了。于是请教他人,最后发现是在数据库连接语句上少了启用rewriteBatchedStatements参数。jdbcTemplate默认在batchUpdate方法中,是一条一条的执行语句。这个在他的驱动代码中可以看到:




所以在连接串上加上

jdbc:mysql://IP:PORT/database?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&rewriteBatchedStatements=true

加上后,重启Tomcat,发现批量执行果然快了。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值