mysql批量提交的优化(转)
?
?
?
?
?
?
横坐标: 一次批量更新的条数。纵坐标:更新100次所用时间(ms)
可见,当批量条数增加时,rewriteBatchedStatements=true的性能有很大优势。即使数量少时,也还是有一定优势。
结论:
使用rewriteBatchedStatements=true参数,对批量操作,性能有较大提高,从官方解释上看,对普通操作没有影响。 从网上资料和自己的测试上看,暂时没有发现rewriteBatchedStatements=true参数Driver版本5.1.17的问题。 因此,本项目中计划采取下面优化措施:
JDBC Driver版本从5.0.4升级到5.1.17。连接属性中加入rewriteBatchedStatements=true参数附:
测试环境:
mysql JDBC 3.0.4/3.1.17。
客户端: 普通PC机。
连接池数: 1-10。
10线程并发,批量更新30条记录(索引有效),循环更新100次。
批量更新主要代码:
mmpSqlMapClient.startTransaction(); // 使用事务
mmpSqlMapClient.startBatch(); // 批量提交
for (ChannelLayoutDO channelLayout: userChannelLayoutList) {????????? ??? mmpSqlMapClient.update(“UserChannelLayoutDAO.updateSort”, channelLayout);
}
mmpSqlMapClient.executeBatch();
mmpSqlMapClient.commitTransaction();