当前位置: 首页 > news >正文

MyBatisPlus实现多表查询

在MyBatisPlus中实现多表查询,主要有以下几种方法:

  1. 使用注解进行多表查询: 你可以在Mapper接口中使用@Select注解来编写SQL查询语句,实现多表查询。例如,如果你想根据用户ID查询用户信息和对应的区域名称,可以这样写:

    @Select("SELECT user.*, area.area_name FROM user, area WHERE user.area_id = area.id AND user.id = #{id}")
    User getUserById(int id);

    这种方法适用于简单的多表查询场景。

  2. 使用MyBatis-Plus Join扩展: MyBatis-Plus Join是一个扩展库,它提供了多表联查的能力。你可以通过配置Join条件来实现多表查询,这种方式更加灵活,适用于复杂的多表查询场景。

  3. 使用XML配置文件进行多表查询: 另一种方法是在Mapper的XML配置文件中定义多表查询的SQL语句。例如:

    <mapper namespace="com.yourpackage.mapper.UserMapper"><resultMap id="userMap" type="com.yourpackage.model.UserVO"><result property="userName" column="name"/><result property="userAge" column="age"/><!-- 其他字段映射 --></resultMap><select id="selectUsers" resultMap="userMap">SELECT u.name, u.age, a.area_nameFROM t_user as uLEFT JOIN t_area as a ON u.area_id = a.id</select>
    </mapper>

    这种方式适用于需要复杂SQL逻辑和字段映射的场景。

  4. 动态查询(通过join): 使用MyBatis-Plus的动态SQL功能,可以在运行时构建多表查询。例如:

    @Select("SELECT t_blog.*, t_user.* " +" FROM t_blog " +"   LEFT JOIN t_user " +"     ON t_blog.user_id = t_user.id " +" ${ew.customSqlSegment} ")
    IPage<BlogVO> findBlogByJoin(IPage<BlogVO> page, @Param("ew") Wrapper wrapper);

    这种方式适用于需要动态构建查询条件的场景。

以上方法可以根据你的具体需求和项目情况选择使用,每种方法都有其适用的场景和优势。

要使用MyBatis-Plus Join扩展(简称MPJ),你可以按照以下步骤进行操作:

  1. 引入依赖: 首先,你需要在你的项目中引入MyBatis-Plus-Join的依赖。如果你使用Maven,可以在pom.xml文件中添加如下依赖:

    <!-- mybatis-plus-join -->
    <dependency><groupId>com.github.yulichang</groupId><artifactId>mybatis-plus-join</artifactId><version>1.1.6</version>
    </dependency>

    确保你的MyBatis-Plus版本大于等于3.4.0。

  2. 配置Mapper扫描: 在你的Spring Boot应用中,确保配置了Mapper接口的扫描路径:

    @MapperScan("com.yourpackage.mapper")
    @SpringBootApplication
    public class YourApplication {public static void main(String[] args) {SpringApplication.run(YourApplication.class, args);}
    }
  3. 使用MPJ进行多表查询: 在你的Mapper接口中,你可以使用MPJ提供的API来构建多表查询。以下是一个简单的例子,展示了如何使用MPJ进行多表联合查询:

    @Override
    public List<ObOutPoolDto> queryByOrderNumber(String orderNumber){List<ObOutPoolDto> list = baseMapper.selectJoinList(ObOutPoolDto.class,mpjLambdaWrapper(MPJ(),new ObOutPoolItem() ,new String[0] ,Signal.ORDER.name,orderNumber));return list;
    }
    //基础连接查询MPJ对象
    @Override
    public MPJLambdaWrapper<ObOutPoolDto> MPJ(){MPJLambdaWrapper<ObOutPoolDto> mpj =  new MPJLambdaWrapper<ObOutPoolDto>().selectAll(ObOutPoolItem.class)    //查询表1所有内容.selectAll(ObPool.class)           //查询表2所有内容.leftJoin(ObPool.class,ObPool::getId,ObOutPoolItem::getPoolId)  //左连接表1,条件为表1库存id 等于 表2 id.leftJoin(ObOutPool.class,ObOutPool::getDrawNumber,ObOutPoolItem::getDrawNumber);  //左连接表2,用订单号匹配return mpj;
    }

    在这个例子中,selectAll方法用于选择要查询的表的所有字段,leftJoin方法用于指定连接的表和连接条件。

  4. 执行查询: 使用构建好的MPJ对象执行查询,获取结果。MPJ提供了selectJoinListselectJoinListPage等方法来执行多表查询,并返回结果列表或分页结果。

通过以上步骤,你可以在你的项目中使用MyBatis-Plus Join扩展来实现多表关联查询。MPJ提供了一种简洁的方式来构建和执行多表查询,无需编写复杂的XML配置文件。

http://www.lryc.cn/news/503443.html

相关文章:

  • 机器学习详解(5):MLP代码详解之MNIST手写数字识别
  • 如何在vue中实现父子通信
  • PHP实现华为OBS存储
  • 嵌入式 linux Git常用命令 抽补丁 打补丁
  • Alan Chhabra:MongoDB AI应用程序计划(MAAP) 为客户提供价值
  • 【学习笔记】目前市面中手持激光雷达设备及参数汇总
  • Burp与小程序梦中情缘
  • 数据结构:Win32 API详解
  • 迁移学习中模型训练加速(以mllm模型为例),提速15%以上
  • socket编程UDP-实现停等机制(接收确认、超时重传)
  • 前端面试题目 (Node.JS-Express框架)[二]
  • 防范TCP攻击:策略与实践
  • 3D 生成重建034-NerfDiff借助扩散模型直接生成nerf
  • 分布式 Paxos算法 总结
  • 我的宝贵经验
  • geoserver 瓦片地图,tomcat和nginx实现负载均衡
  • Jenkins 启动 程序 退出后 被杀死问题
  • SEGGER | 基于STM32F405 + Keil - RTT组件01 - 移植SEGGER RTT
  • 分布式开发学习
  • freeswitch(开启支持MCU视频会议,使用mod_av模块)
  • Vue3常见api使用指南(TS版)
  • 分布式 分布式事务 总结
  • onnx文件转pytorch pt模型文件
  • 智能座舱人机交互升级
  • RabbitMQ中点对点(Point-to-Point)通讯方式的Java实现
  • 爬虫实战:获取1688接口数据全攻略
  • 生成树协议STP工作步骤
  • Android14 AOSP支持短按关机
  • C# 和 go 关于can通信得 整理
  • vue常用命令汇总