服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - Java教程 - MyBatis 实现数据的批量新增和删除的操作

MyBatis 实现数据的批量新增和删除的操作

2021-08-12 10:58pan_junbiao Java教程

这篇文章主要介绍了MyBatis 实现数据的批量新增和删除的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

在项目的开发中,我们经常需要对数据进行批量的操作,如:批量新增、批量删除等。下面将介绍MyBatis如何实现数据的批量新增和删除操作。

创建UserMapper接口(用户信息Mapper动态代理接口),实现用户信息的批量新增、批量删除、批量查询。

  1. package com.pjb.mapper;
  2. import com.pjb.entity.UserInfo;
  3. import org.apache.ibatis.annotations.Delete;
  4. import org.apache.ibatis.annotations.Insert;
  5. import org.apache.ibatis.annotations.Param;
  6. import org.apache.ibatis.annotations.Select;
  7. import org.springframework.stereotype.Repository;
  8. import java.util.List;
  9.  
  10. /**
  11. * 用户信息Mapper动态代理接口
  12. * @author pan_junbiao
  13. **/
  14. @Repository
  15. public interface UserMapper
  16. {
  17. /**
  18. * 批量新增用户
  19. */
  20. @Insert({"<script>",
  21. "INSERT INTO tb_user(user_name,remark) VALUES",
  22. "<foreach collection='userInfoList' item='item' index='index' separator=','>",
  23. "(#{item.userName},#{item.remark})",
  24. "</foreach>",
  25. "</script>"})
  26. public int addUserBatch(@Param("userInfoList") List<UserInfo> userInfoList);
  27.  
  28. /**
  29. * 批量删除用户
  30. */
  31. @Delete({"<script>",
  32. "DELETE FROM tb_user WHERE user_id IN",
  33. "<foreach item='id' index='index' collection='array' open='(' separator=',' close=')'>",
  34. "#{id}",
  35. "</foreach>",
  36. "</script>"})
  37. public int deleteUserBatch(int[] userIds);
  38.  
  39. /**
  40. * 批量获取用户
  41. */
  42. @Select({"<script>",
  43. "SELECT * FROM tb_user WHERE user_id IN",
  44. "<foreach item='id' index='index' collection='array' open='(' separator=',' close=')'>",
  45. "#{id}",
  46. "</foreach>",
  47. "</script>"})
  48. public List<UserInfo> getUserBatch(int[] userIds);
  49. }

1、批量新增

  1. @Autowired
  2. private UserMapper userMapper;
  3.  
  4. /**
  5. * 批量新增用户
  6. * @author pan_junbiao
  7. */
  8. @Test
  9. public void addUserBatch()
  10. {
  11. //创建新用户列表
  12. List<UserInfo> userInfoList = new ArrayList<UserInfo>();
  13. userInfoList.add(new UserInfo("pan_junbiao的博客_01","您好,欢迎访问 pan_junbiao的博客"));
  14. userInfoList.add(new UserInfo("pan_junbiao的博客_02","https://blog.csdn.net/pan_junbiao"));
  15. userInfoList.add(new UserInfo("pan_junbiao的博客_03","您好,欢迎访问 pan_junbiao的博客"));
  16. userInfoList.add(new UserInfo("pan_junbiao的博客_04","https://blog.csdn.net/pan_junbiao"));
  17. userInfoList.add(new UserInfo("pan_junbiao的博客_05","您好,欢迎访问 pan_junbiao的博客"));
  18.  
  19. //执行批量新增操作
  20. int count = userMapper.addUserBatch(userInfoList);
  21.  
  22. //打印结果
  23. System.out.println("执行结果:成功新增" + count + "条数据!");
  24. }

执行结果:

MyBatis 实现数据的批量新增和删除的操作

2、批量查询

  1. @Autowired
  2. private UserMapper userMapper;
  3.  
  4. /**
  5. * 批量获取用户
  6. * @author pan_junbiao
  7. */
  8. @Test
  9. public void getUserBatch()
  10. {
  11. //用户编号数组
  12. int[] userIds = new int[]{1,2,3,4,5};
  13.  
  14. //执行批量获取操作
  15. List<UserInfo> userInfoList = userMapper.getUserBatch(userIds);
  16.  
  17. //打印结果
  18. userInfoList.stream().forEach(System.out::println);
  19. }

执行结果:

MyBatis 实现数据的批量新增和删除的操作

3、批量删除

  1. @Autowired
  2. private UserMapper userMapper;
  3.  
  4. /**
  5. * 批量删除用户
  6. * @author pan_junbiao
  7. */
  8. @Test
  9. public void deleteUserBatch()
  10. {
  11. //用户编号数组
  12. int[] userIds = new int[]{1,2,3,4,5};
  13.  
  14. //执行批量删除操作
  15. int count = userMapper.deleteUserBatch(userIds);
  16.  
  17. //打印结果
  18. System.out.println("执行结果:成功删除" + count + "条数据!");
  19. }

执行结果:

MyBatis 实现数据的批量新增和删除的操作

补充:Mybatis中的批量增加和批量删除,查询和更新

批量增加实例

  1. <insert id="addRoleContent" parameterType="java.util.List">
  2. <foreach collection="List" open="begin" close=";end;" item="item" separator=";">
  3. INSERT INTO YIBO_SYS_CONTENT_ROLE (ROLE_ID,CONTENT_ID) VALUES (#{item.roleId,jdbcType=NUMERIC},#{item.contentId,jdbcType=VARCHAR})
  4. </foreach>
  5. </insert>

foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。foreach元素的属性主要有item,index,collection,open,separator,close。item表示集合中每一个元素进行迭代时的别名,index指 定一个名字,用于表示在迭代过程中,每次迭代到的位置,open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔 符,close表示以什么结束,在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,

主要有一下3种情况:

1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list

2. 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array

3. 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在breast里面也 是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map 里面的key

这是一个带in的实例

  1. <select id="dynamicForeachTest" parameterType="java.util.List" resultType="Blog">
  2. select * from t_blog where id in
  3. <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
  4. #{item}
  5. </foreach>
  6. </select>

图一

MyBatis 实现数据的批量新增和删除的操作

图二

MyBatis 实现数据的批量新增和删除的操作

collection中的值要和注解一致或者和参数名一致。

查询

  1. <select id="editRoleContent" parameterType="com.yibo.modules.datamanage.entity.RoleTieContent" resultType="com.yibo.modules.datamanage.entity.RoleTieContent">
  2. select CONTENT_ID from YIBO_SYS_CONTENT_ROLE where ROLE_ID=#{roleId}
  3. </select>

每个属性含义

id 是dao层的方法名,parameterType传入的参数类型,resultType返回的参数类型,这里是传入RoleTieContent这个类,语句通过#{roleId}去查找RoleTieContent这个类中的属性roleId,赋值给where条件,查询结果返回给RoleTieContent这个类中的countentID属性。

通过调用dao层方法名(id),来实现sql增删改查。

多条件查询

if

choose (when, otherwise)

trim (where, set)

foreach

删除

  1. <delete id="deleteRoleContent" parameterType="java.util.List">
  2. <foreach collection="List" open="begin" close=";end;" item="item" separator=";">
  3. delete from YIBO_SYS_CONTENT_ROLE
  4. where
  5. ROLE_ID=#{item.roleId} and CONTENT_ID=#{item.contentId}
  6. </foreach>
  7. </delete>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/pan_junbiao/article/details/107639673

延伸 · 阅读

精彩推荐
  • Java教程spring security环境搭建

    spring security环境搭建

    本文通过代码给大家介绍了spring security环境搭建的详细教程,非常不错,具有参考借鉴价值,需要的朋友参考下吧...

    动力节点8562021-01-08
  • Java教程深入理解Java中的SPI机制

    深入理解Java中的SPI机制

    这篇文章主要介绍了深入理解Java中的SPI机制,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    码农开花5142021-08-05
  • Java教程spring security自定义认证登录的全过程记录

    spring security自定义认证登录的全过程记录

    这篇文章主要给大家介绍了关于spring security自定义认证登录的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价...

    CatalpaFlat11972021-03-09
  • Java教程Java项目中如何访问WEB-INF下jsp页面

    Java项目中如何访问WEB-INF下jsp页面

    这篇文章主要介绍了Java项目中如何访问WEB-INF下jsp页面,文章通过示例代码和图文解析介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...

    大道之简7442020-08-06
  • Java教程Java学习-打印1-1000以内的水仙花数代码实例

    Java学习-打印1-1000以内的水仙花数代码实例

    这篇文章主要介绍了Java打印1-1000以内的水仙花数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面...

    穆学习5462021-07-28
  • Java教程Java 中 synchronized的用法详解(四种用法)

    Java 中 synchronized的用法详解(四种用法)

    Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。本文给大家介绍java中 synchronized的...

    mrr4832020-01-16
  • Java教程Java垃圾回收finalize()作用详解

    Java垃圾回收finalize()作用详解

    Java 技术允许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去之前做必要的清理工作,这个方法是由垃圾收集器在确定这个对象没有被引用时对这...

    lijiao2802020-01-07
  • Java教程spring @Transactional 无效的解决方案

    spring @Transactional 无效的解决方案

    这篇文章主要介绍了spring @Transactional 无效的解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们...

    dezun11672021-07-26