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

网友投稿 1476 2022-11-13

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

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

目录多个条件使用Map传递参数进行批量删除1、使用场景2、代码实现3、实现结果展现MyBatis 多条件批量删除的sql语句我把这次的代码贴出来,仅供参考

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

1、使用场景

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

实现的项目效果图:

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

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

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

2、代码实现

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

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

/**

* 删除资源标签关系表之中相关信息

* @param deleteTagRelationParams

* @return

*/

int deleteBatchEnclosureTagRelationList(Map deleteTagRelationParams);

delete from course_enclosure_tag where resource_id=#{resourceId} AND tag_id in

#{tagId}

具体业务操作Java代码

if(deleteTagList.size()>0){

List deleteTagIdList=new ArrayList();

for(Map itemMap:deleteTagList) {

Long delTagId=Long.parseLong(itemMap.get("id").toString());

deleteTagIdList.add(delTagId);

}

Map deleteTagRelationParams=new HashMap();

dehttp://leteTagRelationParams.puhttp://t("resourceId", courseEnclosure.getId());

deleteTagRelationParams.put("deleteTagIdList", deleteTagIdList);

deleteBatchEnclosureTagRelationList(deleteTagRelationParams);

}

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

Long delTagId=Long.parseLong(itemMap.get("id").toString());

// 必须是Long定义类型List 如果使用long定义后端无法执行的

long delTagId=Long.parseLong(itemMap.get("id")http://.toString());

3、实现结果展现

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

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

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

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

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

代码如下:

delete from PUB_PRINT_TMPL_COMPUTER

and TMPL_CODE = #{item.tmplCode, jdbcType=VARCHAR}

and TMPL_SEQ = #{item.tmplSeq, jdbcType=INTEGER}

and COMPUTER_CODE = #{item.computerCode,jdbcType=VARCHAR}

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Prometheus学习笔记——启动
下一篇:PG服务进程(Postgres)——向前端发送后端cancellation
相关文章

 发表评论

暂时没有评论,来抢沙发吧~