目录
多个条件使用Map传递参数进行批量删除
1、使用场景
因为项目需要针对资源文件(视频、音频、文档),编辑时候可能出现以下3种情况:
实现的项目效果图:
1.1、删除多个已经选择的标签(与本次文章相关内容)
1.2、新增标签(选择已有标签作为新增,输入新的标签作为新增的)
因为本业务场景之中与此文章相关的内容 重点介绍一下如何,使用Map<String,Object> 参数传递过个参数进行批量删除 资源标签关系表记录信息。
2、代码实现
由于此功能需要在取消选择当前资源标签之中的,以前已经选择过的标签,需要传递两个参数进行删除【资源标签关系记录表】之中的记录,主要有资源id(resourceId),多个标签的ids(deleteTagIdList)。具体代码如下所示:
/** * 删除资源标签关系表之中相关信息 * @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命令未正确结束。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
做猪小侠源码的代理,提供一站式服务
如果你不懂得搭建网站或者服务器,小程序,源码之类的怎么办? 第一通过本站学习各种互联网的技术 第二就是联系客服,我帮帮你搭建(当然要收取部分的费用) 第三成为我们的代理,我们提供整套的服务。