mybatis 根据id批量删除的两种方法
原文:https://blog.csdn.net/qq_40010745/article/details/81032218
mybatis 根据id批量删除的两种方法
第一种,直接传递给mapper.xml 集合/数组形式
- <delete id="deleteByLogic" parameterType = "java.util.List">
- delete from user where 1>2
- or id in
- <foreach collection="list" item="item" open="(" separator="," close=")" >
- #{item}
- </foreach>
- </delete>
1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
int deleteByLogic(List list);
2. 如果传入的是单参数且参数类型是一个array数组的时候, 参数类型为parameterType="int" 集合 collection的属性值为array
int deleteByLogic(int[] array);
- <foreach item="item" collection="array" open="(" separator="," close=")">
- #{item}
- </foreach>
第二种,直接在service中将数据给分装传递到mapper中
前端封装为以,为分隔符的id字符串。调用下方工具类。生成数据类型为(‘12’,‘34’....)形式
- /**
- * StringUtil.getSqlInStrByStrArray()<BR>
- * <P>Author : wyp </P>
- * <P>Date : 2016年6月15日下午6:14:05</P>
- * <P>Desc : 数组字符串转换为SQL in 字符串拼接 </P>
- * @param strArray 数组字符串
- * @return SQL in 字符串
- */
- public static String getSqlInStrByStrArray(String str) {
- StringBuffer temp = new StringBuffer();
- if(StringUtils.isEmpty(str)){
- return "('')";
- }
- temp.append("(");
- if(StringUtils.isNotEmpty(str)){
- String[] strArray=str.split(",");
- if (strArray != null && strArray.length > 0 ) {
- for (int i = 0; i < strArray.length; i++) {
- temp.append("'");
- temp.append(strArray[i]);
- temp.append("'");
- if (i != (strArray.length-1) ) {
- temp.append(",");
- }
- }
- }
- }
- temp.append(")");
- return temp.toString();
- }
在mapper中直接使用 $ 符号接收即可
int deleteByLogic(String ids);
- <delete id="deleteByLogic" parameterType = "java.util.List">
- delete from user where 1>2
- or id in ${ids}
- </delete>
还有第三种。不过比较浪费资源
直接在service中循环调用mapper中的delete方法。.....
mybatis 根据id批量删除的两种方法的更多相关文章
- oracle多表关联删除的两种方法
oracle多表关联删除的两种方法 第一种使用exists方法 delete from tableA where exits ( select 1 from tableB Where tableA.i ...
- mybatis学习之路----批量更新数据两种方法效率对比
原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...
- 【ADO.NET-中级】百万级数据的批量插入的两种方法测试
在SQL Server 中插入一条数据使用Insert语句,但是如果想要批量插入一堆数据的话,循环使用Insert不仅效率低,而且会导致SQL一系统性能问题.下面介绍SQL Server支持的两种批量 ...
- VIM 批量注释的两种方法 (转)
方法一 ctrl+v 进入列编辑模式,向下或向上移动光标,把需要注释的行的开头标记起来,然后按大写的I(shift+i),再插入注释符,比如"//",再按Esc,就会全部注释了 批 ...
- mysql批量update的两种方法
today a question let me happy(抓狂) 头儿分了一个小任务,让修改循环调用dao层的那些不啦不啦不啦,鉴于之前写过批量更新的玩意,so 很快代码就修改完了,but 测的时候 ...
- c#mysql批量更新的两种方法
总体而言update 更新上传速度还是慢. 1: 简单的insert 速度稍稍比MySqlDataAdapter慢一点 配合dapper 配置文件 <?xml version="1 ...
- Windows文件自删除的两种方法
可执行模块的自删除技术已经被讨论的很多, 有很多极富创意的思路和想法被提出, 但有些似是而非的方案往往使人误入歧途. 举个例子来说, 很多文章认为下面的一小段代码可以实现自删除:void main(v ...
- C# 批量新增的两种方法。
public class Test { private static readonly string strConnection = ""; public static void ...
- Mybatis新增返回主键的两种方法 (mysql)
1.自增:LAST_INSERT_ID (自动返回最后一个INSERT或 UPDATE 问询为 AUTO_INCREMENT列设置的第一个 发生的值.) <!-- mysql的自增ID :LAS ...
随机推荐
- 韦大仙--简单的monkey测试命令行操作及生成log日志保存
作中,在将apk交给软件测试人员去测试之前,不免要自己先自测,monkey自测是一个不错的选择! 步骤很简单: 1.测试用的手机与电脑连接好USB ,并且安装好驱动(我一般都是通过豌豆荚自动安装的)! ...
- MaxScript代码补全插件
MaxScript代码补全插件 作者Nik,原文发布于ScriptSpot 安装后max自带脚本编辑器会有自动补全,效果如下:
- Angualr6访问API
参照 草根专栏- ASP.NET Core + Ng6 实战: https://v.qq.com/x/page/a0769armuui.html 1.environment.ts 添加apiUrlBa ...
- 【转】巫师3:狂猎(The Witcher 3: Wild Hunt )的游戏事件工作流
转自腾讯游戏开发者平台(GAD) CDPROJEKT RED的主程序.Piotr Tomsinski 在GDC2016的最后一天18号,CDPROJEKT RED的主程Piotr Tomsinski, ...
- LCD1602指令集解读
LCD1602指令集(11个) 1.清屏指令(clear display) RS=0 ,R/w=0, 01H 功能:清除液晶显示器,即将DDRAM中的内容全部填入20H(空白字符) ...
- 【转】使用CNPM搭建私有NPM
最近的Node项目中因为数据模型等问题,需要有一个对各个模块进行统一的管理,如果把私有的模型publish到公共的npm不太合适,所以决定使用cnpm搭建一个私有的npm,同时也可以对项目常用的npm ...
- 算法与数据结构3.3 calculator
★实验任务 小 V 发明了一个神奇的整数计算器: 给定一个合法的表达式,这个计算器能求出这个表达式的最终答案. 表达式可能包含: +:运算符,整数加法.如 1+1=2 -:运算符,整数减法.如 1-1 ...
- C++第一次课堂作业 circle
Github上的代码提交
- Ligerui首页的快速搭建
一.目录 1.多层架构+MVC+EF+AUTOFAC+AUTOMAPPER: 2.MVC中验证码的实现(经常用,记录备用) 3.Ligerui首页的快速搭建 4.Ligerui Grid组件--学生信 ...
- ZOJ 1711 H-Sum It Up
https://vjudge.net/contest/67836#problem/H Given a specified total t and a list of n integers, find ...