这两天再用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了
分享到:
相关推荐
`JdbcTemplate`的`batchUpdate`方法就是用来实现这样的功能,它可以批量执行更新语句,如INSERT、UPDATE或DELETE。 `batchUpdate`方法的基本使用如下: ```java int[] result = jdbcTemplate.batchUpdate( ...
6. **批量操作**:JDBCTemplate提供`batchUpdate()`方法,可以执行批量的SQL更新语句,提高效率。 7. **性能优化**:JDBCTemplate允许设置执行超时时间、重试次数等,增强了系统的健壮性。 在实际使用中,首先需要...
jdbcTemplate.batchUpdate(sql, batchArgs); } ``` 6. 防止SQL注入 JdbcTemplate使用PreparedStatement来执行SQL,自动防止SQL注入攻击,因为它会正确地转义参数值。 7. 错误处理 如果数据库操作失败,...
在这个例子中,我们使用了`JdbcTemplate`的`batchUpdate`方法来进行批量更新操作,并且在调用该方法之前关闭了`Connection`对象的自动提交功能。如果在执行过程中发生了异常,比如主键冲突导致的插入失败,那么所有...
- 对于批量操作,使用`JdbcTemplate.batchUpdate()`方法。 - 考虑使用`NamedParameterJdbcTemplate`,它可以提供更清晰的命名参数查询。 6. **错误处理和异常转换** `JdbcTemplate`将数据库抛出的`SQLException`...
- **批量更新**:`batchUpdate(String sql, BatchPreparedStatementSetter setter)`方法用于执行批处理更新。 ### 5. **参数绑定** JdbcTemplate支持多种参数绑定,如: - **位置参数**:`?`占位符,通过`Arrays....
3. `batchUpdate`方法:这是批量操作的核心,它可以执行一系列相同结构的SQL语句,适合大批量数据的插入或更新。 4. `query`和`queryForXXX`方法:用于执行SELECT查询。 5. `call`方法:用于调用存储过程或函数。 ...
这通常涉及解析文件,创建数据行的列表,然后使用`batchUpdate`方法将这些行作为批处理语句执行。批处理允许将多条SQL语句作为一个单元提交,从而减少网络通信和数据库事务处理的开销。 3. **Maven依赖:** 为了...
4. 最后,通过`JdbcTemplate`的`batchUpdate`方法执行批量插入操作。它接受SQL语句和`BatchPreparedStatementSetter`作为参数,返回一个整数数组,表示每条SQL语句的受影响行数。 批量删除操作与批量插入类似,但在...
首先,JdbcTemplate的`batchUpdate`方法是用于批量执行SQL语句的,如示例所示。在上述代码中,`batchUpdate`接收一个SQL语句的字符串数组,然后依次执行这些语句。例如,删除角色关联菜单的记录,接着插入新的关联...
在Spring Batch中,JdbcTemplate或JDBCTemplate的batchUpdate()方法常被用来执行SQL的批量更新操作。 【标签】"spring" 表明这个学习资料集主要围绕Spring框架展开,Spring是Java企业级应用开发的主流框架,提供了...
- **批处理**:批量执行SQL语句,提高数据插入或更新的效率。 - **事务管理**:集成Spring的事务管理,能方便地控制事务的边界。 - **异常转换**:将数据库的SQLException转换为更有意义的Spring的...
在上面的示例代码中,我们使用 JdbcTemplate 的 batchUpdate 方法来执行批量插入操作。 结论 本文详细介绍了 Spring Boot 使用 JdbcTemplate 代码实例,包括 JdbcTemplate 的简介、在 Spring Boot 项目中的使用、...
如果需要批量执行SQL语句,JdbcTemplate还提供了`batchUpdate()`方法,可以一次执行多个更新操作。 9. **性能优化**: JdbcTemplate通过缓存预编译的SQL语句(PreparedStatement),提高了性能,并且可以避免多次...
当需要进行批量更新操作时,`JdbcTemplate`提供了`batchUpdate`方法,开发者需要创建自己的`BatchPreparedStatementCreator`和`BatchPreparedStatementSetter`类来处理批量参数的设置。通过`getJdbcTemplate().batch...
6. **批量操作**:JdbcTemplate还支持批量更新,使用`batchUpdate()`方法可以一次执行多条SQL更新语句,提高了性能。 7. **预编译的SQL(PreparedStatement)**:JdbcTemplate默认使用PreparedStatement,这是一个...
在`JdbcTemplate`内部,`batchUpdate`会调用`executeBatch`方法,该方法会将预处理的SQL语句分批发送给数据库执行。数据库如MySQL、Oracle等通常有内置的批量处理机制,可以有效地减少网络通信和数据库资源消耗。 ...
例如,`queryForList`用于返回结果集的列表,`update`用于执行更新操作,`batchUpdate`用于批量执行更新。 4. **参数绑定与类型转换**: `JdbcTemplate`支持参数化查询,通过占位符(如`?`)和参数对象,能够安全...
int[] updateCounts = jdbcTemplate.batchUpdate(sql, batchParams); ``` 10. **异常处理**:Spring会捕获JDBC抛出的异常,并转换为更具体的Spring的DataAccessException,便于统一处理。 11. **DAO层设计**:...