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

总结

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

单层嵌套,就写一层

多层嵌套,就写多层

相关推荐
敲个大西瓜3 天前
mybatis拦截器插件实现数据库字段加解密
mybatis
武子康3 天前
Java-28 深入浅出 Spring 实现简易Ioc-04 在上节的业务下手动实现AOP
java·后端·mybatis
一条泥憨鱼3 天前
苍穹外卖【day6|微信登录与商品浏览功能】
后端·mybatis·苍穹外卖
vx-Biye_Design3 天前
springboot安阳地区研学旅游服务小程序-计算机毕业设计源码12785
java·vue.js·windows·spring boot·tomcat·maven·mybatis
摇滚侠3 天前
MyBatis+Spring+SpringMVC SSM 整合 179-185
java·spring·mybatis
摇滚侠3 天前
MyBatis+Spring+SpringMVC SSM ContextLoaderListener 177-178
java·spring·mybatis
Spring小子4 天前
【Spring Boot + Vue + DeepSeek】从零打造一个AI驱动的智能健康分析系统
java·spring boot·mybatis
武子康4 天前
Java-27 深入浅出 Spring - 实现简易Ioc-03 在上节的业务下手动实现IoC 从 XML 配置到 BeanFactory 反射注入
java·后端·mybatis
柏舟飞流4 天前
Spring Boot 进阶实战:整合 MyBatis、Redis、JWT,搭一个更像真实项目的后端服务
spring boot·redis·mybatis