java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > mybatis 一对多嵌套查询

mybatis 一对多嵌套查询的实现

作者:qq_36608622

本文主要介绍了mybatis 一对多嵌套查询的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在MyBatis中,处理一对多关系的查询主要涉及到关联映射配置以及在Mapper XML文件中编写SQL查询。以下是一个简单的例子说明如何在MyBatis中实现一对多查询。假设我们有两个实体类:User和Order,一个用户可以有多个订单,这是一种一对多的关系。1. 首先,在User实体类中定义一个Order集合属性:

1. 首先,在User实体类中定义一个Order集合属性:

public class Order {
    private int id;
    private String productName;
    // 省略其他属性...

    // 定义User的外键引用
    private int userId;
    private User user; // 可选,取决于是否需要双向关联

    // 省略getter和setter方法...
}

2. 在Order实体类中定义User的外键引用: 

public class User {
    private int id;
    private String username;
    // 省略其他属性...

    // 定义一个Order集合属性
    private List<Order> orders;

    // 省略getter和setter方法...
}

3. 在User的Mapper XML文件中配置一对多关系查询:

<mapper namespace="com.example.mapper.UserMapper">
    <!-- 查询用户基本信息 -->
    <select id="getUserById" parameterType="int" resultType="com.example.entity.User">
        SELECT * FROM user WHERE id = #{id}
    </select>

    <!-- 一对多关联查询用户的所有订单 -->
    <select id="getUserAndOrdersById" parameterType="int" resultType="com.example.entity.User">
        SELECT u.*, o.* FROM user u
        LEFT JOIN order o ON u.id = o.user_id
        WHERE u.id = #{id}
    </select>

    <!-- 使用association标签配置一对一关系 -->
    <resultMap id="userResultMap" type="com.example.entity.User">
        <id property="id" column="id"/>
        <result property="username" column="username"/>
        <!-- 省略其他字段映射 -->

        <!-- 一对多关联映射 -->
        <collection property="orders" ofType="com.example.entity.Order">
            <id property="id" column="order_id"/>
            <result property="productName" column="product_name"/>
            <!-- 省略其他字段映射 -->
            <!-- 设置关联外键 -->
            <association property="user" javaType="com.example.entity.User" column="user_id" select="com.example.mapper.UserMapper.getUserById"/>
        </collection>
    </resultMap>

    <!-- 使用resultMap进行查询 -->
    <select id="getUserWithResultMapById" parameterType="int" resultMap="userResultMap">
        SELECT * FROM user u
        LEFT JOIN order o ON u.id = o.user_id
        WHERE u.id = #{id}
    </select>
</mapper>

 在这里,我们展示了两种一对多查询的方式:

在MyBatisPlus中,处理一对多关系的查询相对较为简便,主要是借助于模型类的关联注解以及特殊的查询方法。以下是一个简化的例子:假设我们有两个实体类:User和Order,一个用户可以有多个订单,这是一种一对多的关系。

1. 首先,在User实体类中定义一个Order集合属性,并使用@TableField注解标明关联关系:

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.util.List;

@TableName("user")
public class User {
    @TableId("id")
    private Long id;
    private String username;

    // 通过@TableField注解关联Order表
    @TableField(exist = false)
    private List<Order> orders;

    // getter和setter方法...
}

2. 在Order实体类中定义User的外键引用:

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;

@TableName("order")
public class Order {
    @TableId("id")
    private Long id;
    private String productName;
    @TableField("user_id")
    private Long userId;

    // getter和setter方法...
}

3. 使用MyBatisPlus的内置方法进行关联查询:

import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.service.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IService<User> {

    public User getUserAndOrders(Long userId) {
        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("id", userId);
        // 使用lambda表达式加载关联的orders
        queryWrapper.lambda().with(User::getOrders);
        return baseMapper.selectOne(queryWrapper);
    }
}

在上述代码中,通过queryWrapper.lambda().with(User::getOrders);这一行,我们告诉MyBatisPlus在查询用户的同时加载关联的订单信息。这样,当你调用getUserAndOrders方法并返回用户对象时,用户对象的orders属性就已经包含了该用户的所有订单信息。注意,为了实现这样的关联查询,还需要确保数据库表结构符合关联关系(例如在order表中有user_id作为外键指向user表的id),并且在对应的UserMapper和OrderMapper中完成了基本的CRUD方法映射。MyBatisPlus会自动处理内部的一对多关联查询逻辑。

到此这篇关于mybatis 一对多嵌套查询的实现的文章就介绍到这了,更多相关mybatis 一对多嵌套查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文