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"
                    ]
                }
            ]
        }
    ]
}

总结

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

单层嵌套,就写一层

多层嵌套,就写多层

相关推荐
Java_SuSheng2 小时前
关于SQLite轻量数据库的研究
java·数据库·spring boot·sqlite·mybatis
计算机学姐8 小时前
基于SpringBoo的地方美食分享网站
java·vue.js·mysql·tomcat·mybatis·springboot·美食
eternal__day13 小时前
第二期:[特殊字符] 深入理解MyBatis[特殊字符]MyBatis基础CRUD操作详解[特殊字符]
java·spring·java-ee·maven·mybatis
麓殇⊙14 小时前
mybatis--多对一处理/一对多处理
java·tomcat·mybatis
技术宝哥16 小时前
解决 Spring Boot 启动报错:数据源配置引发的启动失败
spring boot·后端·mybatis
路在脚下@17 小时前
Spring Boot项目中结合MyBatis实现MySQL的自动主从切换
spring boot·mysql·mybatis
江城月下19 小时前
SOLID原则详解:提升软件设计质量的关键
java·spring·mybatis·软件工程·设计原则·设计规范
卡尔曼的BD SLAMer1 天前
问题 | 针对SSM(Spring + Spring MVC + MyBatis)框架的去Spring MVC强化版学习路线
java·spring·mvc·mybatis
岳轩子2 天前
Mybatis的简单介绍
mybatis