<强>前言强>
在我们做后端服务Dao层开发,特别是大数据批量插入的时候,这时候普通的ORM框架(Mybatis, hibernate, JPA)就无法满足程序对性能的要求了。当然我们又不可能使用原生的JDBC进行操作,那样尽管效率会高,但是复杂度会上升。
综合考虑我们使用弹簧中的JdbcTemplate和具名参数namedParameterJdbcTemplate来进行批量操作。
<强>改造前强>
在开始讲解之前,我们首先来看下之前的JPA是如何批量操作的。
实体类用户:
公开课AppStudent { 私人整数id; 私人整数classId; 私人字符串名称; 私人整数年龄;//伪代码,省略构造和得到,设置方法 }
DynamicQuery伪代码:
@ 公共类DynamicQueryImpl实现DynamicQuery { @PersistenceContext 私人EntityManager em; 公共EntityManager getEntityManager () { 返回em; }//其实就的是循环,使用EntityManager的保存方法循环保存而已 @Override 公共& lt; T>空白saveList (ListresultList) { for (int i=0;我& lt;resultList.size ();我+ +){ T T=resultList.get(我); em.persist (t); } } } >之前 <强>改造后强>
<强> JdbcTemplate 强>
JdbcTemplate提供的主要方法:
<李>执行方法:可以用于执行任何SQL语句,一般用于执行DDL语句;李> <李>更新方法及batchUpdate方法:更新方法用于执行新增,修改,删除等语句;batchUpdate方法用于执行批处理相关语句;李> <李>查询方法及queryForXXX方法:用于执行查询相关语句;李> <李>调用方法:用于执行存储过程,函数相关语句。李>
我们只需要在使用jdbcTemplate类中使用@ autowired进行注入即可:
@ autowired 私人JdbcTemplate JdbcTemplate;批量插入操作:
公共空间batchSave () { List<对象[]比;batchArgs=new ArrayList<对象[]祝辞(); batchArgs。add(新对象[]{1,”小明”,21}); batchArgs。add(新对象[]{2,“小红”,22}); batchArgs。add(新对象[]{3,“露西”,23}); 字符串sql="插入用户(用户名、密码)值(& # 63;& # 63;)”; jdbcTemplate。batchUpdate (sql, batchArgs); } >之前以上基本实现了批量插入功能,但是当数据库字段比较多的时候,再以& # 63;占位符的形式编码的话就可能不是那么好一一对应了,这春天里还提供了SimpleJdbcTemplate (Spring3.1 +以后被标记为过时,到spring 4.3则被完全移除,后面这个完全能满足需求)和NamedParameterJdbcTemplate模板引擎。
<强> NamedParameterJdbcTemplate 强>
相信使用过Hibernate的同学都知道,HQL中可以使用?或者:*的方式在外部配置查询参数。在Spring JDBC框架中,也提供了一种绑定SQL参数的方式,使用具名参数(命名参数)。
我们只需要在使用NamedParameterJdbcTemplate类中使用@ autowired进行注入即可:
@ autowired 私人NamedParameterJdbcTemplate NamedParameterJdbcTemplate; >之前批量插入操作:
公共空间batchSave () { List列表=new ArrayList ();//新增用户 列表。添加(新AppStudent(1,“张三”,21)); 列表。添加(新AppStudent(1,“李四”,22)); 列表。添加(新AppStudent(1,“王二麻子”,23));//批量转数组 SqlParameterSource [] beanSources=SqlParameterSourceUtils.createBatch (list.toArray ()); 字符串sql="插入app_student (class_id、名字、年龄)值(:classId:名称、年龄)”; namedParameterJdbcTemplate。batchUpdate (sql, beanSources); } >之前 最后我们使用System.currentTimeMillis()来对比打印一下具体改造前后的执行时间。
长开始=System.currentTimeMillis ();//改造前后代码,自行补充 长债=System.currentTimeMillis (); System.out.println(“花费时间:“+ (end-start)); >之前快肯定是快了,至于快多少,那就要根据数据量以及机器配置来做相关的对比了。
项目源码:https://gitee.com/52itstyle/spring-data-jpa
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
SpringBoot JdbcTemplate批量操作的示例代码