mybatis-plus一对多关联查询

MyBatis-Plus 本身主要关注单表操作,但可以通过几种方式实现一对多关联查询:

1. 使用 XML 映射文件实现

这是最传统的方式,通过编写 SQL 和 ResultMap 实现:

XML 复制代码
<!-- UserMapper.xml -->
<resultMap id="userWithOrdersMap" type="com.example.User">
    <id property="id" column="id"/>
    <result property="name" column="name"/>
    <!-- 一对多关联 -->
    <collection property="orders" ofType="com.example.Order">
        <id property="id" column="order_id"/>
        <result property="orderNo" column="order_no"/>
        <result property="userId" column="user_id"/>
    </collection>
</resultMap>

<select id="selectUserWithOrders" resultMap="userWithOrdersMap">
    SELECT u.*, o.id as order_id, o.order_no, o.user_id
    FROM user u
    LEFT JOIN order o ON u.id = o.user_id
    WHERE u.id = #{id}
</select>

2. 使用注解方式实现

MyBatis 也支持通过注解实现:

java 复制代码
public interface UserMapper extends BaseMapper<User> {
    @Select("SELECT * FROM user WHERE id = #{id}")
    @Results({
        @Result(id=true, property="id", column="id"),
        @Result(property="name", column="name"),
        @Result(property="orders", column="id",
                many=@Many(select="com.example.mapper.OrderMapper.selectByUserId"))
    })
    User selectUserWithOrders(Long id);
}

public interface OrderMapper extends BaseMapper<Order> {
    @Select("SELECT * FROM order WHERE user_id = #{userId}")
    List<Order> selectByUserId(Long userId);
}

3. 使用 MyBatis-Plus 的关联查询插件

可以集成第三方插件如 mybatis-plus-join

java 复制代码
// 添加依赖后使用
public List<User> getUserWithOrders() {
    return joinLambdaWrapper(User.class)
            .leftJoin(Order.class, Order::getUserId, User::getId)
            .selectAll(User.class)
            .selectAs(Order::getId, User::getOrderId)
            .selectAs(Order::getOrderNo, User::getOrderNo)
            .list();
}
相关推荐
iCxhust12 分钟前
C#进程管理程序
开发语言·汇编·stm32·单片机·c#·微机原理
凡人叶枫19 分钟前
Effective C++ 条款28:避免使用 handles 指向对象内部
linux·服务器·开发语言·c++·嵌入式开发
技术小结-李爽20 分钟前
【工具】Maven的下载、安装、使用
java·maven
极创信息23 分钟前
Linux挖矿病毒深度清理实战教程,从进程隐藏、Rootkit驻留到彻底根除
java·大数据·linux·运维·安全·tomcat·健康医疗
努力成为AK大王29 分钟前
并发编程的核心挑战、优化方案与核心知识点总结
java·开发语言·数据库
云烟成雨TD32 分钟前
Agent Scope Java 2.x 系列【10】技能(Skill)
java·人工智能·agent
摇滚侠36 分钟前
SpringMVC 入门到实战 DispatcherServlet 源码解读 92-95
java·后端·spring·maven·intellij-idea
AI 编程助手GPT1 小时前
用 Python 做一个世界杯赛前分析脚本:以巴西 vs 摩洛哥为例
开发语言·网络·人工智能·python·chatgpt
键盘歌唱家1 小时前
Spring AI 入门分享:它和“直接调 API“到底差在哪
java·人工智能·spring
lihao lihao1 小时前
Linux信号
开发语言·c++·算法