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

 更新时间:2021年12月20日 14:28:26   作者:蜀山雪松  
这篇文章主要介绍了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命令未正确结束。

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

相关文章

  • IDEA中如何移除未使用的包

    IDEA中如何移除未使用的包

    这篇文章主要介绍了IDEA中如何移除未使用的包问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • 多数据源如何实现事务管理

    多数据源如何实现事务管理

    Spring中涉及三个核心事务处理接口:PlatformTransactionManager、TransactionDefinition和TransactionStatus,PlatformTransactionManager提供事务操作的基本方法,如获取事务、提交和回滚
    2024-09-09
  • SpringBoot整合spring-data-jpa的方法

    SpringBoot整合spring-data-jpa的方法

    这篇文章主要介绍了SpringBoot整合spring-data-jpa的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • SpringBoot实现EMQ设备的上下线告警

    SpringBoot实现EMQ设备的上下线告警

    EMQX 的上下线系统消息通知功能在客户端连接成功或者客户端断开连接,需要实现设备的上下线状态监控,所以本文给大家介绍了如何通过SpringBoot实现EMQ设备的上下线告警,文中有详细的代码示例,需要的朋友可以参考下
    2023-10-10
  • Java应用多机器部署解决大量定时任务问题

    Java应用多机器部署解决大量定时任务问题

    这篇文章主要介绍了Java应用多机器部署解决大量定时任务问题,两台服务器同时部署了同一套代码, 代码中写有spring自带的定时任务,但是每次执行定时任务时只需要一台机器去执行,需要的朋友可以参考下
    2019-07-07
  • SpringBoot如何使用Scala进行开发的实现

    SpringBoot如何使用Scala进行开发的实现

    这篇文章主要介绍了SpringBoot如何使用Scala进行开发的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • 如何计算Java对象占用了多少空间?

    如何计算Java对象占用了多少空间?

    在Java中没有sizeof运算符,所以没办法知道一个对象到底占用了多大的空间,但是在分配对象的时候会有一些基本的规则,我们根据这些规则大致能判断出来对象大小,需要的朋友可以参考下
    2016-01-01
  • Java过滤器doFilter里chain.doFilter()函数的理解

    Java过滤器doFilter里chain.doFilter()函数的理解

    这篇文章主要介绍了Java过滤器doFilter里chain.doFilter()函数的理解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Java实现基础银行ATM系统

    Java实现基础银行ATM系统

    这篇文章主要为大家详细介绍了Java实现基础银行ATM系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • springboot vue 跨域问题的解决

    springboot vue 跨域问题的解决

    这篇文章主要介绍了springboot vue 跨域问题的解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10

最新评论