MyBatis 多个条件使用Map传递参数进行批量删除方式

作者:蜀山雪松 时间:2023-11-29 08:09:01 

多个条件使用Map传递参数进行批量删除

1、使用场景

因为项目需要针对资源文件(视频、音频、文档),编辑时候可能出现以下3种情况:

实现的项目效果图:

MyBatis 多个条件使用Map传递参数进行批量删除方式

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 多个条件使用Map传递参数进行批量删除方式

MyBatis 多个条件使用Map传递参数进行批量删除方式

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

标签:MyBatis,Map,传递参数,批量删除
0
投稿

猜你喜欢

  • JAVA OutputStreamWriter流的实现

    2021-08-12 19:45:47
  • Redisson RedLock红锁加锁实现过程及原理

    2022-12-29 20:49:42
  • java 中HashCode重复的可能性

    2021-09-13 17:38:05
  • springboot实现maven多模块和打包部署

    2022-01-06 00:41:15
  • C++实现特殊矩阵的压缩存储算法

    2023-11-17 23:53:06
  • WinForm实现移除控件某个事件的方法

    2021-09-25 02:57:58
  • Flutter实现切换应用时隐藏应用预览

    2021-07-20 21:05:46
  • C#实现简单的天气预报示例代码

    2022-03-22 22:52:59
  • C语言根据协议分割获取字符串单元的实现代码

    2023-06-21 08:20:27
  • java数据结构和算法中哈希表知识点详解

    2023-08-05 08:28:11
  • Java实现经典游戏复杂迷宫

    2021-05-29 22:33:34
  • Android编程使用GestureDetector实现简单手势监听与处理的方法

    2021-11-18 17:07:43
  • C#实现计算器窗体程序

    2023-04-09 01:25:42
  • C#网络编程中常用特性介绍

    2021-09-03 23:07:51
  • C# 字符串的连接(实例讲解)

    2021-11-28 13:57:14
  • 详解使用SSM实现简单工作流系统之实现篇

    2021-10-21 07:49:23
  • Java SWT中常见弹出框实例总结

    2023-08-22 00:42:22
  • Unity 点击UI与点击屏幕冲突的解决方案

    2022-02-22 15:50:49
  • 详解java接口基础知识附思维导图

    2023-11-09 10:07:28
  • IDEA JetBrains Mono字体介绍和安装教程(详解)

    2022-01-23 17:57:51
  • asp之家 软件编程 m.aspxhome.com