MyBatis 多个条件使用Map传递参数进行批量删除方式
作者:蜀山雪松 发布时间:2023-11-29 08:09:01
标签:MyBatis,Map,传递参数,批量删除
多个条件使用Map传递参数进行批量删除
1、使用场景
因为项目需要针对资源文件(视频、音频、文档),编辑时候可能出现以下3种情况:
实现的项目效果图:
1.1、删除多个已经选择的标签(与本次文章相关内容)
1.2、新增标签(选择已有标签作为新增,输入新的标签作为新增的)
因为本业务场景之中与此文章相关的内容 重点介绍一下如何,使用Map<String,Object> 参数传递过个参数进行批量删除 资源标签关系表记录信息。
2、代码实现
由于此功能需要在取消选择当前资源标签之中的,以前已经选择过的标签,需要传递两个参数进行删除【资源标签关系记录表】之中的记录,主要有资源id(resourceId),多个标签的ids(deleteTagIdList)。具体代码如下所示:
Java接口定义及MyBatis语句定义代码
/**
* 删除资源标签关系表之中相关信息
* @param deleteTagRelationParams
* @return
*/
int deleteBatchEnclosureTagRelationList(Map<String, Object> deleteTagRelationParams);
<!-- 批量删除 课程资源标签 -->
<delete id="deleteBatchEnclosureTagRelationList" parameterType="hashmap">
delete from course_enclosure_tag where resource_id=#{resourceId} AND tag_id in
<foreach collection="deleteTagIdList" item="tagId" separator="," open="(" close=")">
#{tagId}
</foreach>
</delete>
具体业务操作Java代码
if(deleteTagList.size()>0){
List<Long> deleteTagIdList=new ArrayList<Long>();
for(Map<String, Object> itemMap:deleteTagList) {
Long delTagId=Long.parseLong(itemMap.get("id").toString());
deleteTagIdList.add(delTagId);
}
Map<String, Object> deleteTagRelationParams=new HashMap<String, Object>();
deleteTagRelationParams.put("resourceId", courseEnclosure.getId());
deleteTagRelationParams.put("deleteTagIdList", deleteTagIdList);
deleteBatchEnclosureTagRelationList(deleteTagRelationParams);
}
注意事项:deleteTagIdList 参数的List<Long>类型一定要和接口函数之中的类型一致;本人定义接口参数
Long delTagId=Long.parseLong(itemMap.get("id").toString());
// 必须是Long定义类型List 如果使用long定义后端无法执行的
long delTagId=Long.parseLong(itemMap.get("id").toString());
3、实现结果展现
MyBatis 多条件批量删除的sql语句
今天在写代码的过程中,有一个批量删除的需求,且这个删除的条件是三个字段组成的联合主键。
一开始我们新手可能会想到在service层使用for循环来多次调用mapper层的删除方法,这样虽然能够实现功能,但是消耗的系统资源很多,效率不高。
我也在网上找了找,发现这样的例子很少
我把这次的代码贴出来,仅供参考
代码如下:
<delete id="deletePubPrintTmplComputers" parameterType="java.util.List">
delete from PUB_PRINT_TMPL_COMPUTER
<foreach collection="listData" item="item" separator="or" index="index">
<where>
<if test="item.tmplCode != null">
and TMPL_CODE = #{item.tmplCode, jdbcType=VARCHAR}
</if>
<if test="item.tmplSeq != null">
and TMPL_SEQ = #{item.tmplSeq, jdbcType=INTEGER}
</if>
<if test="item.computerCode != null">
and COMPUTER_CODE = #{item.computerCode,jdbcType=VARCHAR}
</if>
</where>
</foreach>
</delete>
这里是使用foreach语法进行批量操作,要特别注意的是,在每个if判断中,条件语句末尾不要加逗号,不然会报错,显示sql命令未正确结束。
来源:https://blog.csdn.net/jianxia801/article/details/86673534


猜你喜欢
- 今天有朋友问我一道面试题,有5个人抢5个红包,可重复抢,用多线程程序实现,实现方式有多种,分享一下我的思路:应用了阻塞队列的特性。/**
- 前言《布谷鸟闯关-简单版》是一个基于java的布谷鸟闯关游戏,摁上键控制鸟的位置穿过管道间的缝隙,需要做碰撞检测,监听键盘事件,背景图片的切
- BigDecimal 和 0 比较大小调用BigDecimal中的compareTo方法, 如:int i = bigDecimal.com
- MyBatis-Plus 使用简单,内置通用 Mapper、通用 Service,仅仅通过少量配置,即可实现单表大部分 CRUD 操作。下面
- /*开机自动启动APP*/public class BootReceiver extends BroadcastReceiver {@Ove
- 在 C# 中,程序中在运行时出现的错误,会不断在程序中进行传播,这种机制称为“异常”。异常通常由错误的代码引发,并由能够更正错误的代码进行
- WPF实现一个简单的多运算符表达式计算器,供大家参考,具体内容如下1.先看下效果图首先外围给了一个grid 把他分成了两行 第一行用来显示文
- 前序(先序)遍历中序遍历后续遍历层序遍历如图二叉树:二叉树结点结构public class TreeNode { int val
- 本文实例为大家分享了C语言实现学生成绩管理系统的具体代码,供大家参考,具体内容如下结构体版的学生成绩管理系统主要功能有按1 输入学生信息按2
- 定义注解也叫原数据,它是JDK1.5及之后版本引入的一个特性,它可以声明在类、方法、变量等前面,用来对这些元素进行说明。作用生成文档:通过代
- 1、继承Thread类方式这种方式适用于执行特定任务,并且需要获取处理后的数据的场景。举例:一个用于累加数组内数据的和的线程。public
- 本文实例为大家分享了javafx tableview鼠标触发更新属性,供大家参考,具体内容如下public class HoverCell
- Android深入浅出之Binder机制一 说明 Android系统最常见也是初学者最难搞明白的就是Binder了,很多很多的Se
- (1)实际应用BeanUtils.copyProperties(赋值目标对象,模板源对象);我们都知道当有两个对象AB,属性名称一样的情况下
- Android安全加密专题文章索引Android安全加密:对称加密Android安全加密:非对称加密Android安全加密:消息摘要Mess
- 本文实例为大家分享了Android实现双曲线折线图的具体代码,供大家参考,具体内容如下先看一下效果图1.先下载jar包 mpandroidc
- 前沿页面通用Loading组件是一个App必不可少的基础功能,之前只开发过Android原生的页面Loading,这次就按原生的逻辑再开发一
- java 中同步、异步、阻塞和非阻塞区别详解简单点说:阻塞就是干不完不准回来,一直处于等待中,直到事情处理完成才返回; 非阻塞就是你先干,我
- zip 是一个非常常见的压缩包格式,本文主要用于说明如何使用代码 文件或文件夹压缩为 zip压缩包及其解压操作,我们采用的是 微软官方的实现
- 本文实例讲述了java实现单词搜索迷宫游戏。分享给大家供大家参考。具体分析如下:我们在杂志上,经常能够看到找单词的小游戏,在一个二维表格中,