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

2023-01-21 0 4,907

目录

多个条件使用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命令未正确结束。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 MyBatis 多个条件使用Map传递参数进行批量删除方式 http://www.20zxx.cn/463029/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务