原文:https://blog.csdn.net/qq_40010745/article/details/81032218

mybatis 根据id批量删除的两种方法

 

第一种,直接传递给mapper.xml  集合/数组形式

  1. <delete id="deleteByLogic" parameterType = "java.util.List">
  2. delete from user where 1>2
  3.     or id in
  4. <foreach collection="list" item="item" open="(" separator="," close=")" >
  5.      #{item}
  6. </foreach>
  7. </delete>
 

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

int deleteByLogic(List list);

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

int deleteByLogic(int[] array);
 
  1. <foreach item="item" collection="array" open="(" separator="," close=")">
  2. #{item}
  3. </foreach>

第二种,直接在service中将数据给分装传递到mapper中
    前端封装为以,为分隔符的id字符串。调用下方工具类。生成数据类型为(‘12’,‘34’....)形式

  1. /**
  2. * StringUtil.getSqlInStrByStrArray()<BR>
  3. * <P>Author : wyp </P>
  4. * <P>Date : 2016年6月15日下午6:14:05</P>
  5. * <P>Desc : 数组字符串转换为SQL in 字符串拼接 </P>
  6. * @param strArray 数组字符串
  7. * @return SQL in 字符串
  8. */
  9. public static String getSqlInStrByStrArray(String str) {
  10. StringBuffer temp = new StringBuffer();
  11. if(StringUtils.isEmpty(str)){
  12. return "('')";
  13. }
  14. temp.append("(");
  15. if(StringUtils.isNotEmpty(str)){
  16. String[] strArray=str.split(",");
  17. if (strArray != null && strArray.length > 0 ) {
  18. for (int i = 0; i < strArray.length; i++) {
  19. temp.append("'");
  20. temp.append(strArray[i]);
  21. temp.append("'");
  22. if (i != (strArray.length-1) ) {
  23. temp.append(",");
  24. }
  25. }
  26. }
  27. }
  28. temp.append(")");
  29. return temp.toString();
  30. }
  31.  

在mapper中直接使用 $ 符号接收即可

int deleteByLogic(String ids);
  1. <delete id="deleteByLogic" parameterType = "java.util.List">
  2. delete from user where 1>2
  3. or id in ${ids}
  4. </delete>

还有第三种。不过比较浪费资源

        直接在service中循环调用mapper中的delete方法。.....

mybatis 根据id批量删除的两种方法的更多相关文章

  1. oracle多表关联删除的两种方法

    oracle多表关联删除的两种方法 第一种使用exists方法 delete from tableA where exits ( select 1 from tableB Where tableA.i ...

  2. mybatis学习之路----批量更新数据两种方法效率对比

    原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...

  3. 【ADO.NET-中级】百万级数据的批量插入的两种方法测试

    在SQL Server 中插入一条数据使用Insert语句,但是如果想要批量插入一堆数据的话,循环使用Insert不仅效率低,而且会导致SQL一系统性能问题.下面介绍SQL Server支持的两种批量 ...

  4. VIM 批量注释的两种方法 (转)

    方法一 ctrl+v 进入列编辑模式,向下或向上移动光标,把需要注释的行的开头标记起来,然后按大写的I(shift+i),再插入注释符,比如"//",再按Esc,就会全部注释了 批 ...

  5. mysql批量update的两种方法

    today a question let me happy(抓狂) 头儿分了一个小任务,让修改循环调用dao层的那些不啦不啦不啦,鉴于之前写过批量更新的玩意,so 很快代码就修改完了,but 测的时候 ...

  6. c#mysql批量更新的两种方法

    总体而言update 更新上传速度还是慢. 1:  简单的insert  速度稍稍比MySqlDataAdapter慢一点 配合dapper 配置文件 <?xml version="1 ...

  7. Windows文件自删除的两种方法

    可执行模块的自删除技术已经被讨论的很多, 有很多极富创意的思路和想法被提出, 但有些似是而非的方案往往使人误入歧途. 举个例子来说, 很多文章认为下面的一小段代码可以实现自删除:void main(v ...

  8. C# 批量新增的两种方法。

    public class Test { private static readonly string strConnection = ""; public static void ...

  9. Mybatis新增返回主键的两种方法 (mysql)

    1.自增:LAST_INSERT_ID (自动返回最后一个INSERT或 UPDATE 问询为 AUTO_INCREMENT列设置的第一个 发生的值.) <!-- mysql的自增ID :LAS ...

随机推荐

  1. grep命令及正则

    文本查找 grep,egrep,fgrep grep :Global Research 根据模式搜索文本,并将符合模式的文本行显示出来 模式:Pattern,文本字符和正则的元字符组合而成匹配条件 g ...

  2. Java开发工程师(Web方向) - 02.Servlet技术 - 第3章.Servlet应用

    第3章.Servlet应用 转发与重定向 转发:浏览器发送资源请求到ServletA后,ServletA传递请求给ServletB,ServletB生成响应后返回给浏览器. 请求转发:forward: ...

  3. spring boot 报错 Error creating bean with name

    Application 启动类 要和父目录平级

  4. python程序设计——面向对象程序设计:类

    理解面向对象 基本原则是,计算机程序由多个能够起到子程序作用的单元或对象组合而成 关键性观念是,数据以及对数据的操作封装在一起,组成一个相互依存.不可分割的整体,即对象 python面向对象特性 完全 ...

  5. windows 7 安装docker

    下载docker-install.exe 下载链接 安装,一路next(安装完成后建议重启电脑) 点击桌面boot2docker Start图标,等待初始化,运行docker --version检验是 ...

  6. KVM存储虚拟化---玩转openstack

    KVM 的存储虚拟化是通过存储池(Storage Pool)和卷(Volume)来管理的. Storage Pool 是宿主机上可以看到的一片存储空间,可以是多种类型,后面会详细讨论.Volume 是 ...

  7. jQuery File Upload文件上传插件简单使用

    前言 开发过程中有时候需要用户在前段上传图片信息,我们通常可以使用form标签设置enctype=”multipart/form-data” 属性上传图片,当我们点击submit按钮的时候,图片信息就 ...

  8. Python的string模块化方法

    Python 2.X中曾经存在过一个string模块,这个模块里面有很多操作字符串的方法,但是在Python 3.X中,这些模块化方法已经被移除了(但是string模块本身没有被移除,因为它还有其他可 ...

  9. 环境变量PATH

    一.举例 我在用户主文件夹执行命令“ls”,会在屏幕显示该文件夹下的所有文件.然而,ls的完整文件名为“/bin/ls”,按道理我不在/bin下要想执行ls命令必须输入“/bin/ls”,但我仅仅需要 ...

  10. Pipeline组项目Postmortem

    Pipeline组项目Postmortem 1.     设想和目标 1)目标我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的项目是学霸系统PipeLine, ...