这两天再用jdbcTemplate.batchUpdate方法的时候遇到了一些小问题,拿出来分享一下。
数据库使用的是mysql5.6版本。由于项目中需要一次性插入多条数据,所以使用jdbcTemplate的batchUpdate批量执行的方法,方法如下:
public void batchSave(List<Object[]> list) {
String sql = "xxxxxxxxxx";
jdbcTemplate.batchUpdate(sql, list);
}
在使用了该方法之后发现,插入1000条数据,需要耗时几秒钟,这很明显是有问题的,按正常来讲,插入1000条数据,时间应该在几十毫秒。之后发现实际上这1000条数据并没有一次性的插入到数据库中,而是一条一条的向数据库中插入的,那效率必然很低啊。
之后再百度上搜索了一下,好多论坛上说是使用这种方法,如下:
/***************************************************************************
* 批量更新
*
* @param list
*/
public void batchUpdateLinkset(final List list) {
String sql = "update LINK_SET set N_CONFIRM=?,TIME_STAMP=?,DOMAIN_ID=?,SIGLINKSET_NAME=? where NE_ID=?";
jdbctemp.batchUpdate(sql, new BatchPreparedStatementSetter() {
public int getBatchSize() {
return list.size(); //这个方法设定更新记录数,通常List里面存放的都是我们要更新的,所以返回list.size();
}
public void setValues(PreparedStatement ps, int i)
throws SQLException {
Linkset linkset = (Linkset) list.get(i);
ps.setString(1, linkset.getCHINA_NAME());
ps.setString(2, linkset.getENGLISH_NAME());
ps.setInt(3, linkset.getN_CONFIRM());
ps.setString(4, linkset.getTIME_STAMP());
ps.setInt(5, linkset.getDOMAIN_ID());
ps.setString(6, linkset.getSIGLINKSET_NAME());
ps.setString(7, linkset.getNE_ID());
}
});
}
但是改成这种形式之后还是不行,也是一条一条入库的。
没办法,只能上spring的官方网站上看一下原版的api了。
果然,在api中出现了这样一句话:Will fall back to separate updates on a single Statement if the JDBC driver does not support batch updates.
大致意思就是如果JDBC驱动程序不支持批量更新,将变成单条插入。
OK,那么肯定就是jdbc驱动的配置的问题了,最后经过查找
MySql连接的url中要加rewriteBatchedStatements参数,例如
String connectionUrl="jdbc:mysql://192.168.1.100:3306/test?rewriteBatchedStatements=true";
还要保证mysql JDBC驱的版本。MySql的JDBC驱动的批量插入操作性能是很优秀的。
然后再使用jdbcTemplate.batchUpdate方法,插入1000条数据,30毫秒就OK了
分享到:
相关推荐
NULL 博文链接:https://rayfuxk.iteye.com/blog/2286519
jdbc批量方法。多个sql语句可以一起执行
15熟悉集成JdbcTemplate.md
NULL 博文链接:https://summerbell.iteye.com/blog/364702
spring中使用JdbcTemplate操作数据库crud,一图详解(脑图)
JdbcTemplate.rar
spring 封装了 RedisTemplate,JdbcTemplate 对象来进行对redis,jdbc的各种操作进行简化
使用spring+springmvc+jdbcTemplate 数据库使用orcal、redis 完成一个webdemo
spring提供了一个工具类JdbcTemplate,在类中对JDBC增删改查做了封装 JdbcTemplate: Spring 框架中提供一个ORM技术,对JDBC进行了封装 类似于我们之前的mybatis框架,对数据库做增删改查操作的 学习目标:了解该技术...
JDBC的封装
spring-jdbc(jdbctemplate)所需jar包 spring建立持久数据库,简化数据库连接代码,spring-jdbc(jdbctemplate)所需jar包
保存jdbcTemplate的一些jar包,其中包含commons-logging-1.2.jar、spring-beans-5.0.0.RELEASE.jar、spring-core-5.0.0.RELEASE.jar、spring-jdbc-5.0.0.RELEASE.jar、spring-tx-5.0.0.RELEASE.jar
使用druid连接池之后,为了简化代码书写,使用JDBCTemplate。该压缩包为所需要的jar包。
主要介绍了Java 使用JdbcTemplate 中的queryForList发生错误解决办法的相关资料,需要的朋友可以参考下
spring JdbcTemplate query方法使用示例,欢迎下载借鉴
1.Spring4前 spring-jdbc包是独立的,4以后spring-jdbc 就已经没有了
学习Spring JDBC,Spring提供了一个JDBC Template对象简化JDBC的开发,需要导入相关jar包。
主要介绍了使用jdbcTemplate查询返回自定义对象集合代码示例,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
JDBCTemplateDemo.java