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

版权声明:来至蜀山雪松 https://blog.csdn.net/jianxia801/article/details/86673534

目录

1、使用场景

2、代码实现

3、实现结果展现

4、参考文章:


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);
}

3、实现结果展现

4、参考文章:

mybatis 批量删除 (map)

猜你喜欢

转载自blog.csdn.net/jianxia801/article/details/86673534
今日推荐