SpringBoot JdbcTemplate批量操作的示例代码

  

<强>前言

  

在我们做后端服务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批量操作的示例代码