MybatisPlus两表关联查询MyBatis-Plus-Join

news2024/11/27 22:27:23

MybatisPlus两表关联查询MyBatis-Plus-Join

介绍

mybatisplusjin

首先,让我们先了解一下MyBatis和MyBatis-Plus。MyBatis是一个流行的Java持久层框架,它提供了一种简单而强大的方式来将数据库操作与Java代码进行绑定。而MyBatis-Plus是基于MyBatis的增强工具,它提供了更多便捷的功能和特性,让我们能够更高效地进行数据库操作。

现在,让我们进入重头戏——MyBatis-Plus-Join!它是MyBatis-Plus框架中的一个强大功能,旨在简化数据库表的连接操作。你知道吗,通常在数据库中,我们会有多个表之间的关联关系。以学生和班级为例,一个班级可能有多个学生,而一个学生只属于一个班级。在过去,要实现学生和班级的数据关联查询,我们需要手动编写复杂的SQL语句。但是现在,有了MyBatis-Plus-Join,一切都变得轻松起来!

使用MyBatis-Plus-Join,你只需简单地定义实体之间的关系,然后让框架来为你处理连接查询。你可以像使用普通的实体类一样操作关联查询,而无需关心复杂的SQL语句。这大大简化了我们的开发工作,减少了出错的可能性。

而且,MyBatis-Plus-Join还支持多种类型的连接查询,包括内连接、左连接和右连接等。这样,无论是想要获取匹配的数据还是包含全部数据,我们都能轻松搞定。

总之,MyBatis-Plus-Join是一个让数据库表连接操作变得简单又高效的神奇工具。它让我们摆脱繁琐的SQL语句,以更直观的方式进行关联查询。如果你是一个热爱数据库操作的开发者,那么MyBatis-Plus-Join绝对是你不可或缺的利器!

使用

依赖引入

<dependency>
      <groupId>com.github.yulichang</groupId>
      <artifactId>mybatis-plus-join-boot-starter</artifactId>
      <version>1.4.6</version>
</dependency>

关联查询

baseMapper.selectJoinPage(page, StoreEntity.class, new MPJLambdaWrapper<StoreEntity>()
                .selectAll(StoreEntity.class)
                .select(DealerEntity::getDealerName)
                .leftJoin(DealerEntity.class, DealerEntity::getId, StoreEntity::getDistributorId)
                .eq(store.getStatus() != null, StoreEntity::getStatus, store.getStatus()));

说明:

StoreEntity.class是最终返回的DTO

new MPJLambdaWrapper<StoreEntity>()中的StoreEntity是主表查询的实体类

.selectAll(StoreEntity.class)是查询主表的全部字段

.select(DealerEntity::getDealerName)是查询字表的dealerName字段

.leftJoin(DealerEntity.class, DealerEntity::getId, StoreEntity::getDistributorId)是表关联,DealerEntity.class是字表实体类,DealerEntity::getId关联字表的字段,StoreEntity::getDistributorId关联主表的字段

.eq(store.getStatus() != null, StoreEntity::getStatus, store.getStatus())这个就是其他的条件查询啦,跟MP是一样的

以上执行SQL打印
select t.id,
       t.store_code,
       t.store_name,
       t.distributor_id,
       t.status,
       t.contact_person,
       t.contact_phone,
       t.store_location,
       t.position_lon,
       t.position_lat,
       t.create_by,
       t.create_time,
       t.update_by,
       t.update_time,
       t.dept_id,
       t.tenant_id,
       t.del_flag,
       # 这个是字表的字段
       t1.dealer_name
from tb_store t
         left join tb_dealer t1 on t1.id = t.distributor_id and t1.tenant_id = 1
where t.del_flag = '0'
  and t1.del_flag = '0'
  and t.tenant_id = 1
limit 10

是不是跟写关联查询的sql是一样的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1042174.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【异常报错】must call Vue.use(Vuex)

这个错误应该是在创建Vuex中出现的 把你main.js中的Vue.use(Vuex)写到store中&#xff0c;这里我的store/index.js中,即完美解决 其实仔细想想也可以发现&#xff0c;import就把整个文件给引入了&#xff0c;而index.js中有创建Store的实例&#xff0c;而在这时我们还没有Vue.…

【JAVA进阶】多线程

&#x1f4c3;个人主页&#xff1a;个人主页 &#x1f525;系列专栏&#xff1a;JAVASE基础 前言&#xff1a; 什么是线程&#xff1f; 线程(thread)是一个程序内部的一条执行路径。 我们之前启动程序执行后&#xff0c;main方法的执行其实就是一条单独的执行路径。 public…

使用HHDBCS管理Redis

Redis是一款内存高速缓存数据库&#xff0c;可用于缓存&#xff0c;事件发布或订阅&#xff0c;高速队列等场景。 因此&#xff0c;根据需要&#xff0c;HHDBCS在主页设置了“发布窗口”及“订阅窗口”。 1 连接redis 打开HHDBCS&#xff0c;在数据库类型中选择Redis&#…

MATLAB实战 | 粮食储仓的通风控制问题

粮食储仓的通风控制问题 01、应用实战 【例1】粮食储仓的通风控制问题。在粮食储备中&#xff0c;合适的湿度是保证粮食质量的前提。一般来说&#xff0c;若粮食水分的吸收和蒸发量相等&#xff0c;这个湿度称为平衡点湿度。只有实际湿度处于平衡点湿度以下&#xff0c;粮食质…

SpringMVC-请求与相应

一、环境准备 <dependencies><dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>3.1.0</version><scope>provided</scope> //确定范围避免与tomcat冲突</de…

iOS-自定义Intent及ShortCut,能通过快捷指令唤醒APP并跳转到指定页面

1.Xcode->New->File->搜索Intent 2.在新建的intent文件中中New intent 3.完善资料&#xff0c;内容可自定义 4.创建Extension&#xff0c;file -> new -> target , 选择 Intents Extension 即可 创建完成后&#xff0c;在intents文件中勾选以下target&#xff0…

独步全球:为何TikTok成为创业者的首选平台?

在当今数字时代&#xff0c;社交媒体平台的崛起已经成为了创业者们开展业务、推广产品和建立品牌的关键方式。 然而&#xff0c;在众多社交媒体平台中&#xff0c;TikTok正以惊人的速度崭露头角&#xff0c;成为越来越多创业者的首选平台。本文将深入探讨为何TikTok如此吸引创…

双指数移动平均线DEMA指标公式,减少传统均线的滞后性

双指数移动平均线DEMA由Patrick Mulloy发明的&#xff0c;对指数移动平均线EMA进行了改进&#xff0c;用于减少传统均线的滞后性&#xff0c;于1994年发表在美国金融类月刊《Technical Analysis of Stocks & Commodities》。 双指数移动平均线DEMA是通过两个指数移动平均线…

MyBatis 执行流程分析

文章目录 1. MyBatis 执行流程概述2. MyBatis 配置文件详解3. Mappers 映射器 1. MyBatis 执行流程概述 上篇文章讲到 MyBatis入门 MyBatis 的基本入门案例我们实现了通过 MyBatis 去获取数据库的数据&#xff0c;那么他的基本流程如下&#xff1a; 第一步&#xff1a;是从配置…

linux 归档和压缩文件和目录

打包&#xff1a; tar 是 Unix 和 Linux 系统中非常常用的命令之一。它可以将多个文件和目录打包成一个归档文件&#xff0c;并且支持压缩和解压缩功能。 将文件或&#xff08;和&#xff09;目录打包成一个归档文件 tar -cvf Arithmetic_Ghost.tar file1 file2 directory/…

如何在 Spring MVC 中处理表单提交

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

校物联网智慧安全用电平台的设计和运用-安科瑞黄安南

一.前言 安全用电历来都是学校安全工作的一个重点&#xff0c;然而每年因此发生的人身伤害以及火灾事故却在继续着&#xff0c;究其原因&#xff0c;主观上是我们的防患意识淡薄&#xff0c;客观上则是由于学生在宿舍使用违规电器、乱拉电线造成的。 现代的大学生宿舍&#x…

第二章 计算机系统基础知识笔记

计算机划分为硬件和软件 二、硬件部分 2.1 处理器 CISC&#xff1a;x86结构的复杂指令集 RISC&#xff1a;arm和power的精简指令集 2.2 存储器 片上缓存&#xff1a;在CPU里的集成缓存&#xff0c;SRAM&#xff0c;16KB~512KB。不同性能划分成一级或二级片外缓存&#xf…

LeetCode力扣020:有效的括号

有效的括号 实现思路 设立判定条件遍历的范围 代码实现 class Solution(object):def isValid(self, s):""":type s: str:rtype: bool"""nlen(s)for i in range(0,n-1):if s[i]( and s[i1]!):return Falseif s[i][ and s[i1]!]:return Falseif s…

macOS 中 Apple Distribution 与 Apple Development 证书不受信任解决方法

造成这个现象的原因是 Worldwide Developer Relations 中间关系证书缺失 我们只需要将相关证书下载并导入到「系统」级钥匙串即可 首先访问网站&#xff1a;https://www.apple.com/certificateauthority 下载右侧 Apple Intermediate Certificates 下方的如下证书 Develope…

正则表达式的应用(前端写法)

文章目录 1、匹配字符串中&#xff0c;a标签的href值2、校验邮箱3、校验手机号码3、待添加... 1、匹配字符串中&#xff0c;a标签的href值 (1) 代码 /*** description 匹配字符串中&#xff0c;a标签的href值* param {string} str 匹配的字符串* return {Array} 返回href值*/…

【算法练习Day6】四数相加赎金信三数之和四数之和

​ ​&#x1f4dd;个人主页&#xff1a;Sherry的成长之路 &#x1f3e0;学习社区&#xff1a;Sherry的成长之路&#xff08;个人社区&#xff09; &#x1f4d6;专栏链接&#xff1a;练题 &#x1f3af;长路漫漫浩浩&#xff0c;万事皆有期待 文章目录 四数相加赎金信三数之和…

驱动开发---基于gpio子系统编写LED灯的驱动

一、GPIO子系统相关API 1.解析GPIO相关的设备树节点 struct device_node *of_find_node_by_path(const char *path) 功能&#xff1a;根据设备树节点路径解析设备树节点信息 参数&#xff1a; path&#xff1a;设备树所在的节点路径 /mynode0X12345678 返回值&#xff1a;成…

【Aurora 8B/10B IP(1)--初步了解】

Aurora 8B/10B IP(1)–初步了解 1 Aurora 8b/10b IP的基本状态: •通用数据通道吞吐量范围从480 Mb/s到84.48 Gb/s •支持多达16个连续粘合7GTX/GTH系列、UltraScale™ GTH或UltraScale+™ GTH收发器和4绑定GTP收发器 •Aurora 8B/10B协议规范v2.3顺从的 •资源成本低(请参…

环保电商:可持续发展在跨境电子商务中的崭露头角

近年来&#xff0c;环保意识的崛起和可持续发展的重要性日益凸显&#xff0c;已成为全球关注的焦点。在这个背景下&#xff0c;电子商务行业也逐渐加入了可持续发展的浪潮&#xff0c;形成了新的商业机会。 跨境电子商务领域&#xff0c;一股环保电商的潮流正崭露头角&#xf…