MybatisPlus多表关联查询详解

一、MybatisPlus概述

MybatisPlus是一个基于Mybatis的增强工具,它简化了Mybatis的开发流程,提供了大量的便捷功能,例如通用Mapper、分页插件等。其中,多表关联查询是MybatisPlus中的重要功能之一。

二、实现多表关联查询的方式

MybatisPlus可以通过Mapper XML文件、注解以及Wrapper查询等方式实现多表关联查询。

1. Mapper XML文件

通过Mapper XML文件,我们可以使用Mybatis的SQL语句进行多表关联查询。具体的实现过程如下:

<select id="findUserAndOrder" resultMap="userOrderResultMap">
    select * from user u left join order o on u.id = o.user_id
</select>

其中,resultMap是MybatisPlus提供的查询结果映射器,用于将查询结果与Java对象进行映射。关于resultMap的详细使用方式,可以参考Mybatis官方文档。

2. 注解

使用注解的方式可以极大地简化MybatisPlus的开发流程,具体实现如下:

@GetMapping("/findUserAndOrder")
public ResultDTO findUserAndOrder() {
    List list = userOrderMapper.findUserAndOrder();
    return ResultDTO.success(list);
}

@Select("select u.*,o.order_no,o.order_time from user u left join `order` o on u.id = o.user_id")
List<UserOrderDTO> findUserAndOrder();

在上述实现中,我们使用了@Select注解来标识查询语句,并结合Java对象来完成结果映射。

3. Wrapper查询

Wrapper查询是MybatisPlus中的一种高级查询方式,它可以通过Lambda表达式进行动态查询,如下所示:

UserOrderDTO dto = new UserOrderDTO();
...
QueryWrapper<UserOrderDTO> wrapper = new QueryWrapper<>(dto);
wrapper.select("id","username");
wrapper.eq("id", 1);
wrapper.or(qw -> qw.eq("order_no", "10001").eq("order_no","10002"));

List<UserOrderDTO> list = userOrderMapper.selectList(wrapper);

在Wrapper查询中,我们可以通过select方法指定查询的字段,通过eq方法、like方法等进行动态查询,同时还可以使用or方法进行条件组合查询。

三、多表关联查询的常用方法

1. 多表关联查询-单表查询

单表查询是多表关联查询中的基本查询方式,它可以通过直接调用Mapper中的select方法实现。例如:

List<User> userList = userMapper.selectList(null);

2. 多表关联查询-多表左连接

多表左连接是多表关联查询中最常用的方式之一,它可以通过关联字段将多个表进行左连接查询,如下所示:

List<UserOrderDTO> list = userOrderMapper.findUserAndOrder();

3. 多表关联查询-多表右连接

多表右连接是多表关联查询中的一种方式,它与多表左连接相似,只是将多个表进行右连接查询。实现方式如下:

Select<UserRoleDTO> select = new LambdaQueryChainWrapper<>(userRoleMapper)
        .select(UserRoleDTO::getId, UserRoleDTO::getUsername, UserRoleDTO::getRoleName)
        .leftJoin(User.class, User::getId, UserRoleDTO::getUserId)
        .in(UserRoleDTO::getRoleName, Arrays.asList("admin", "user"));

List<UserRoleDTO> list = select.list();

4. 多表关联查询-多表内连接

多表内连接是多表关联查询中的一种方式,它可以将多个表进行内连接查询,如下所示:

Select<OrderProductDTO> select = new LambdaQueryChainWrapper<>(orderProductMapper)
        .eq(OrderProductDTO::getOrderId, 1)
        .eq(OrderProductDTO::getProductId, 1)
        .select(OrderProductDTO::getId, OrderProductDTO::getProductId, OrderProductDTO::getProductName, OrderProductDTO::getOrderNo);

List<OrderProductDTO> list = select.list();

5. 多表关联查询-多表嵌套查询

多表嵌套查询适用于多表关联度较高的查询场景,它可以通过子查询的方式将多个表进行嵌套查询,如下所示:

Select<UserDTO> select = new LambdaQueryChainWrapper<>(userMapper)
        .in(User::getId, new LambdaQueryChainWrapper<>(orderMapper)
                .eq(Order::getOrderNo, "10001")
                .select(Order::getUserId)
        );

List<UserDTO> list = select.list();

四、代码示例

下面是一个完整的示例代码,其中包含了各种多表关联查询方式:

@RestController
@RequestMapping("/api")
public class OrderAdminController {

    @Autowired
    private UserMapper userMapper;

    @Autowired
    private OrderMapper orderMapper;

    @Autowired
    private ProductMapper productMapper;

    @Autowired
    private OrderProductMapper orderProductMapper;

    @Autowired
    private UserRoleMapper userRoleMapper;

    @GetMapping("/findUserAndOrder")
    public ResultDTO findUserAndOrder() {
        List<UserOrderDTO> list = userOrderMapper.findUserAndOrder();
        return ResultDTO.success(list);
    }

    @GetMapping("/findUserRoleByName")
    public ResultDTO findUserRoleByName(String username) {
        List<UserRoleDTO> list = new LambdaQueryChainWrapper<>(userRoleMapper)
                .select(UserRoleDTO::getId, UserRoleDTO::getUsername, UserRoleDTO::getRoleName)
                .leftJoin(User.class, User::getId, UserRoleDTO::getUserId)
                .eq(User::getUsername, username)
                .in(UserRoleDTO::getRoleName, Arrays.asList("admin", "user"))
                .list();
        return ResultDTO.success(list);
    }

    @GetMapping("/findProductAndOrder")
    public ResultDTO findProductAndOrder() {
        List<OrderProductDTO> list = new LambdaQueryChainWrapper<>(orderProductMapper)
                .eq(OrderProductDTO::getOrderId, 1)
                .eq(OrderProductDTO::getProductId, 1)
                .select(OrderProductDTO::getId, OrderProductDTO::getProductId, OrderProductDTO::getProductName, OrderProductDTO::getOrderNo)
                .list();
        return ResultDTO.success(list);
    }

    @GetMapping("/findUserByOrderNo")
    public ResultDTO findUserByOrderNo(String orderNo) {
        List<UserDTO> list = new LambdaQueryChainWrapper<>(userMapper)
                .in(User::getId, new LambdaQueryChainWrapper<>(orderMapper)
                        .eq(Order::getOrderNo, orderNo)
                        .select(Order::getUserId)
                )
                .list();
    return ResultDTO.success(list);
    }
}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/272093.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-17 00:08
下一篇 2024-12-17 00:08

相关推荐

  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25
  • Python安装OS库详解

    一、OS简介 OS库是Python标准库的一部分,它提供了跨平台的操作系统功能,使得Python可以进行文件操作、进程管理、环境变量读取等系统级操作。 OS库中包含了大量的文件和目…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25

发表回复

登录后才能评论