服务器之家

服务器之家 > 正文

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

时间:2021-08-12 10:58     来源/作者:pan_junbiao

在项目的开发中,我们经常需要对数据进行批量的操作,如:批量新增、批量删除等。下面将介绍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

标签:

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部