mybatis-plus 实现一对多查询,返回VO对象某个字段为List

类关系

Animal类下包含一个List<Dog》,两表可用type字段关联。

@Data
@TableName("animal")
public class Animal {
    @TableId
    private String id;
    private Integer type;
    private List<Dog> dogList;
}

@Data
@TableName("dog")
public class Dog {
    @TableId
    private String id;
    private Integer type;
    private String name;
    private Integer age;
    private String color;
}

表中数据:
在这里插入图片描述
在这里插入图片描述

问题

期望获得:


    {
        "id": "1",
        "type": 1,
        "dogList": [
            {
                "id": "1",
                "type": "1",
                "name": "dogA",
                "age": 3,
                "color": "black"
            },
            {
                "id": "2",
                "type": "1",
                "name": "dogB",
                "age": 4,
                "color": "red"
            }
        ]
    }

实际查询:
当用sql查询时animal和dog是一对多关系,会获得两条数据:
在这里插入图片描述

mybatis处理

1、写resultMap,注意collection标签还有两表重名字段要使用别名

collection 标签内放List下Dog类的字段,重名字段id和type如果不使用别名会报 duplicate column name …的错误。

    <resultMap id="AnimalMap" type="org.example.VO.Animal">
        <id column="id" property="id" />
        <result column="type" property="type" />
        <!--        注意ofType写List中的类    -->
        <collection property="dogList" ofType="com.mylearn.heimaspringboot.domain.Dog">
            <id column="dog_id" property="id" />
            <result column="dog_type" property="type" />
            <result column="name" property="name" />
            <result column="age" property="age" />
            <result column="color" property="color" />
        </collection>
    </resultMap>

2、sql

    <select id="findAnimal" resultMap="AnimalMap">
        SELECT a.id,a.type,
                d.id dog_id, d.type dog_type, d.name, d.age, d.color
        FROM animal a
            LEFT JOIN dog d ON a.type=d.type
    </select>

调接口查询可以发现数据已拼接好

[
    {
        "id": "1",
        "type": 1,
        "dogList": [
            {
                "id": "1",
                "type": "1",
                "name": "dogA",
                "age": 3,
                "color": "black"
            },
            {
                "id": "2",
                "type": "1",
                "name": "dogB",
                "age": 4,
                "color": "red"
            }
        ]
    }
]

备注

mybatis中collection和association的作用以及用法

  • 4
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Systemd

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值