mybatis 嵌套List

主查询

xml 复制代码
<!-- 查询车型列表(基于 pdtAliasId 查询) -->
<select id="selectNestedList" resultMap="NestedResultMap">
    SELECT
    t.MAKE,
    t.MODEL,
    t.YEAR

    FROM L_CAR_MODEL_YEAR_${lan} t

第一层嵌套

xml 复制代码
<resultMap id="NestedResultMap" type="com.launch.lcar.model.NestedCarModelResult">
    <result property="make" column="MAKE"/>
    <collection property="models" ofType="com.launch.lcar.model.NestedCarModelResult$ModelDetail"
                resultMap="ModelDetailResultMap"/>
</resultMap>

第二层嵌套

xml 复制代码
<resultMap id="ModelDetailResultMap" type="com.launch.lcar.model.NestedCarModelResult$ModelDetail">
    <result property="model" column="MODEL"/>
    <collection property="years" ofType="java.lang.String" resultMap="YearResultMap"/>
</resultMap>

第三层嵌套

xml 复制代码
<resultMap id="YearResultMap" type="java.lang.String">
    <result column="YEAR"/>
</resultMap>

嵌套实体类

java 复制代码
public class NestedCarModelResult implements Serializable {
    private String make;
    private List<ModelDetail> models;

    public static class ModelDetail implements Serializable {
        private String model;
        private List<String> years;

返回结果

json 复制代码
{
    "code": 0,
    "flag": 0,
    "msg": "success",
    "data": [
        {
            "make": "别克(中国)",
            "models": [
                {
                    "model": "君威",
                    "years": [
                        "2009",
                        "2010",
                        "2011",
                        "2012",
                        "2013",
                        "2014",
                        "2015",
                        "2016",
                        "2017",
                        "2018",
                        "2019",
                        "2020",
                        "2021",
                        "2022",
                        "2023",
                        "2024"
                    ]
                }
            ]
        }
    ]
}

总结

单层嵌套和多层嵌套,都可以

单层嵌套,就写一层

多层嵌套,就写多层

相关推荐
问道飞鱼6 小时前
【Springboot进阶】springboot+mybatis+jsqlparser实现数据权限控制
mybatis·springboot·jsqlparser·数据权限
小杜-coding7 小时前
黑马点评day02(缓存)
java·spring boot·redis·后端·spring·maven·mybatis
努力的搬砖人.12 小时前
Spring Boot 集成 Solr 的详细步骤及示例
spring boot·mybatis·solr
王天华帅哥12 小时前
解决因字段过长使MYSQL数据解析超时导致线上CPU告警问题
spring·mybatis
xuanjiong14 小时前
Javaweb项目--Mybatis,导入com.mysql.cj.jdbc.Driver时报错,Cannot resolve class ‘Driver‘
数据库·mysql·mybatis
计算机学姐1 天前
基于SpringBoot的同城宠物照看管理系统
java·vue.js·spring boot·后端·mysql·mybatis·宠物
爱尚你19931 天前
MyBatis 核心类详解与架构解析:从入门到源码级理解
mybatis
小杜-coding2 天前
黑马点评day01(基于Redis)
java·数据库·spring boot·redis·spring·缓存·mybatis
Code哈哈笑2 天前
【图书管理系统】环境介绍、设计数据库和表、配置文件、引入依赖
java·数据库·spring boot·后端·mybatis
漫步者TZ2 天前
【Mytais系列】介绍、核心概念
mybatis