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 小时前
SpringBoot3 | MyBatis-Plus 搞定宠物管理:从0到1实现增删改查
mybatis·宠物
沙白猿13 小时前
Redis报错:A bean with that name has already been defined in class path resource
spring boot·redis·mybatis
小马爱打代码16 小时前
MyBatis设计模式:构建者、工厂、代理模式
设计模式·mybatis·代理模式
柒.梧.1 天前
SSM常见核心面试问题深度解析
java·spring·面试·职场和发展·mybatis
rabbit_pro1 天前
Java使用Mybatis-Plus封装动态数据源工具类
java·python·mybatis
IT_Octopus2 天前
java 实体属性 Map 解决 mybatis-plus wrapper selectone 查mysql json类型为null 问题
java·mysql·mybatis
Dolphin_Home2 天前
MyBatis 核心属性详解笔记(由浅入深)
笔记·mybatis
一直都在5722 天前
MyBatis入门:CRUD、参数处理与防 SQL 注入
java·sql·mybatis
while(1){yan}2 天前
MyBatis Generator
数据库·spring boot·java-ee·mybatis