经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
MyBatis 多个条件使用Map传递参数进行批量删除方式
来源:jb51  时间:2021/12/20 15:28:13  对本文有异议

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

1、使用场景

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

实现的项目效果图:

1.1、删除多个已经选择的标签(与本次文章相关内容)

1.2、新增标签(选择已有标签作为新增,输入新的标签作为新增的)

因为本业务场景之中与此文章相关的内容 重点介绍一下如何,使用Map<String,Object> 参数传递过个参数进行批量删除 资源标签关系表记录信息。

2、代码实现

由于此功能需要在取消选择当前资源标签之中的,以前已经选择过的标签,需要传递两个参数进行删除【资源标签关系记录表】之中的记录,主要有资源id(resourceId),多个标签的ids(deleteTagIdList)。具体代码如下所示:

Java接口定义及MyBatis语句定义代码

  1. /**
  2. * 删除资源标签关系表之中相关信息
  3. * @param deleteTagRelationParams
  4. * @return
  5. */
  6. int deleteBatchEnclosureTagRelationList(Map<String, Object> deleteTagRelationParams);
  7. <!-- 批量删除 课程资源标签 -->
  8. <delete id="deleteBatchEnclosureTagRelationList" parameterType="hashmap">
  9. delete from course_enclosure_tag where resource_id=#{resourceId} AND tag_id in
  10. <foreach collection="deleteTagIdList" item="tagId" separator="," open="(" close=")">
  11. #{tagId}
  12. </foreach>
  13. </delete>

具体业务操作Java代码

  1. if(deleteTagList.size()>0){
  2. List<Long> deleteTagIdList=new ArrayList<Long>();
  3. for(Map<String, Object> itemMap:deleteTagList) {
  4. Long delTagId=Long.parseLong(itemMap.get("id").toString());
  5. deleteTagIdList.add(delTagId);
  6. }
  7. Map<String, Object> deleteTagRelationParams=new HashMap<String, Object>();
  8. deleteTagRelationParams.put("resourceId", courseEnclosure.getId());
  9. deleteTagRelationParams.put("deleteTagIdList", deleteTagIdList);
  10. deleteBatchEnclosureTagRelationList(deleteTagRelationParams);
  11. }

注意事项:deleteTagIdList 参数的List<Long>类型一定要和接口函数之中的类型一致;本人定义接口参数

  1. Long delTagId=Long.parseLong(itemMap.get("id").toString());
  2. // 必须是Long定义类型List 如果使用long定义后端无法执行的
  3. long delTagId=Long.parseLong(itemMap.get("id").toString());

3、实现结果展现

MyBatis 多条件批量删除的sql语句

今天在写代码的过程中,有一个批量删除的需求,且这个删除的条件是三个字段组成的联合主键。

一开始我们新手可能会想到在service层使用for循环来多次调用mapper层的删除方法,这样虽然能够实现功能,但是消耗的系统资源很多,效率不高。

我也在网上找了找,发现这样的例子很少

我把这次的代码贴出来,仅供参考

代码如下:

  1. <delete id="deletePubPrintTmplComputers" parameterType="java.util.List">
  2. delete from PUB_PRINT_TMPL_COMPUTER
  3. <foreach collection="listData" item="item" separator="or" index="index">
  4. <where>
  5. <if test="item.tmplCode != null">
  6. and TMPL_CODE = #{item.tmplCode, jdbcType=VARCHAR}
  7. </if>
  8. <if test="item.tmplSeq != null">
  9. and TMPL_SEQ = #{item.tmplSeq, jdbcType=INTEGER}
  10. </if>
  11. <if test="item.computerCode != null">
  12. and COMPUTER_CODE = #{item.computerCode,jdbcType=VARCHAR}
  13. </if>
  14. </where>
  15. </foreach>
  16. </delete>

这里是使用foreach语法进行批量操作,要特别注意的是,在每个if判断中,条件语句末尾不要加逗号,不然会报错,显示sql命令未正确结束。

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号