Spring JdbcTemplate批量更新速度很慢的问题
来源:互联网 发布:打投做数据是什么 编辑:程序博客网 时间:2024/05/01 16:48
由于一次要执行很多条插入语句(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,发现批量执行果然快了。
0 0
- Spring JdbcTemplate批量更新速度很慢的问题
- Spring的JDBCTemplate批量更新的性能问题
- spring JdbcTemplate批量更新
- spring jdbcTemplate批量更新操作
- Spring批量更新JdbcTemplate.batchUpdate()
- Spring批量更新JdbcTemplate.batchUpdate()
- spring jdbcTemplate批量更新数据
- Spring批量更新JdbcTemplate.batchUpdate()
- Spring批量更新JdbcTemplate.batchUpdate()
- Spring JdbcTemplate 批量插入或更新操作
- Spring JdbcTemplate 批量插入或更新操作
- Spring JdbcTemplate 批量插入或更新操作
- java Spring jdbcTemplate 批量更新数据 Mysql
- Spring JdbcTemplate 批量插入或更新操作
- Spring JdbcTemplate 批量插入或更新操作
- Spring JdbcTemplate 批量插入或更新操作
- Spring JdbcTemplate 批量插入或更新操作
- InnoDB表类型更新速度慢的问题
- 哈夫曼树编码C语言实现
- [LeetCode]236. Lowest Common Ancestor of a Binary Tree
- 互联网《运营之光》
- ISE综合后得到的RTL图如何与硬件对应起来,怎么知道每个element的功能
- vulkanAPI学习笔记(零)
- Spring JdbcTemplate批量更新速度很慢的问题
- 数据库
- Unity3D铰链关节的简单实例
- more effective c++——Item M30 代理类(二)通过代理类识别operator[]的读写操作
- 555. Split Concatenated Strings
- 多线程学习01:Semaphore信号量的用法
- Python第二坑--安装库
- ChildrenToFitScreen.cs
- Codeforces Round #411 (Div. 1)(A~D)题解