mybatis in foreach 双层嵌套问题
作者:回首掏88 发布时间:2023-11-24 12:55:47
标签:mybatis,in,foreach,双层嵌套
mybatis in foreach 双层嵌套
需求:根据角色id,返回角色名称,
入参是List<List> 类型的二维数组,需要返回一个对应的集合,集合的元素是逗号分隔的字符串。
dao层代码:
List<String> queryRoleName(List<List<Long>> list);
mapper代码:
<select id="queryRoleName" parameterType="java.util.List" resultType="string">
<foreach collection="list" item="item" separator="union all">
select ifnull(group_concat(role_name),'') roleName from sys_role where role_id in
<if test="item!=null and item.size()>0">
/*就像java for循环嵌套一样,外层的item的属性值和内层的collection属性值需要保持一致*/
<foreach collection="item" item="roleId" separator="," open="(" close=")">
#{roleId}
</foreach>
</if>
<if test="item==null">
(null)
</if>
</foreach>
</select>
说明:
1、因为这里业务需求,可能出现传参角色id为null的情况,所以加了if动态标签判断item元素是否为空,并对返回结果的null值,用mysql的ifnull,对null转了空字符串处理
2、逗号分隔分组函数 group_concat()
效果:
入参:
{{null},{1,2},…}
sql解析:
select ifnull(GROUP_CONCAT(role_name),'') roleName from sys_role where role_id in(null)
union all select ifnull(GROUP_CONCAT(role_name),'') roleName from sys_role where role_id in(1,2)
union all ......
查询结果:
mybatis foreach标签进行嵌套插入
场景说明
现有一插入操作,要求按照指定格式进行插入操作。具体格式如下:
上面各对象中对应的表字段:
处理过程
第一层实体类:
public class StudioCourseAddUpdateDto implements Serializable {
private static final long serialVersionUID = 4862281856286977081L;
private int studioId;
private List<CourseInfoDto> courseInfoDtoList;
// 省略get/set
}
第二层实体类:
public class CourseInfoDto implements Serializable {
private static final long serialVersionUID = -2975706030949793781L;
private int courseType;
private List<CourseDetailInfoDto> courseDetailInfoDtoList;
// 省略get/set
}
第三层实体类:
public class CourseDetailInfoDto implements Serializable {
private static final long serialVersionUID = -1423166674509217993L;
private int courseId;
private String feeCount;
// 省略get/set
}
mapper接口:
int bathAddStudioCourseInfo(@Param("studioCourseAddUpdateDtoList") List<courseAddUpdateDto> courseAddUpdateDtoList);
配置文件:
<insert id="bathAddStudioCourseInfo" parameterType="com.it.tao.CourseAddUpdateDto">
<foreach collection="courseAddUpdateDtoList" item="courseAddUpdateDto" >
<foreach collection="courseAddUpdateDto.courseInfoDtoList" item="courseInfoDto" >
<foreach collection="courseInfoDto.courseDetailInfoDtoList" item="courseDetailInfoDto" >
INSERT INTO card_course (course_id,studio_id,course_type,fee_count) VALUES
(#{courseDetailInfoDto.courseId},#{courseAddUpdateDto.studioId},#{courseInfoDto.courseType},#{courseDetailInfoDto.feeCount});
</foreach>
</foreach>
</foreach>
</insert>
来源:https://blog.csdn.net/weixin_41650051/article/details/115696849


猜你喜欢
- 1、首先 当然是启动genymotion2、然后Tomcat ,启动tomcat。。如图将请求的URL地址变为10.0.3.2 ,比如在电脑
- Java Exception 捕获和显示实例详解 在进行Java B/S架构开发时,经常有这样的场景:后端处理业务逻辑,前端负责
- 本文实例讲述了Java Spring开发环境搭建及简单入门示例。分享给大家供大家参考,具体如下:前言虽然之前用过Spring,但是今天试着去
- 前言最近在学习Kotlin这门语言,在项目开发中,运用到了单例模式。因为其表达方式与Java是不同的。所以对不同单例模式的实现进行了分别探讨
- 通过一个变量控制线程中断代码:package com.itsoku.chat05;import java.util.concurrent.T
- 下文我们介绍两种双击事件拦截的方式1.通过Android的事件分发机制进行拦截(dispatchTouchEvent)话不多说,直接上代码:
- 本文将通过AOP的方式实现一个相对更加简易灵活的API安全认证服务。我们先看实现,然后介绍和分析AOP基本原理和常用术语。一、Authori
- pom.xml配置<dependency> <groupId>org.springframework.
- 前言小小知识,不值一提,了解了也不能让你提高身价,但是不了解你就是比别人少知道点!事儿就是这么个事儿,直接正题吧! 直接看代码演示优先级当方
- web.xml中设置:<servlet> <servlet-name>DisplayChart</servle
- 其他的不多说了!我们来看看效果吧 一、实现方式一:直接引入compile方式A
- 前言OpenTelemetry作为一个分布式追踪的项目,他支持非常多的语言,如Java,Golang,Python等,鉴于笔者的主力语言为J
- 1. 线程的5种状态从操作系统层面上,任何线程一般都具有五种状态,即创建、就绪、运行、阻塞、终止。(1) 新建状态(NEW)在程序中用构造方
- 前言:在 Java 语言中,并发编程都是依靠线程池完成的,而线程池的创建方式又有很多,但从大的分类来说,线程池的创建总共分为两大类:手动方式
- 在前面都写到用AsyncTask来获取网络中的图片。其实利用消息机制也能获取网络中的图片,而且本人感觉用消息机制还是挺简单的。消息机制的图解
- 在网上拷贝的所有阿里云镜像比如:<mirror> <id>nexus-aliyun</id>
- 实例如下:package com.huad.luck;import java.util.ArrayList;import java.util
- 快速排序的原理:选择一个关键值作为基准值。比基准值小的都在左边序列(一般是无序的),比基准值大的都在右边(一般是无序的)。一般选择序列的第一
- 这篇总结的形式是提出个问题,然后给出问题的答案。这是目前学习知识的一种尝试,可以让学习更有目的。Q1.什么时候应当重写对象的equals方法
- 实现形式elevationMaterial Design提供了View的阴影效果设置。主要由两个属性决定:elevation和transla