【粉丝投稿】一文带你了解MySQL的左连接与右连接

news2024/11/24 1:04:58

前言:
昨天粉丝问了一个问题,因此本篇文章主要讲解MySQL的左连接和右连接的知识。该专栏比较适合刚入坑Java的小白以及准备秋招的大佬阅读。

如果文章有什么需要改进的地方欢迎大佬提出,对大佬有帮助希望可以支持下哦~

小威在此先感谢各位小伙伴儿了😁

在这里插入图片描述

以下正文开始

文章目录

  • 左查询(LEFT JOIN)
  • 右查询(RIGHT JOIN)
  • 案例说明
    • student_id | student_name | class_name
    • student_id | student_name | class_name

在MySQL中,左查询和右查询是通过使用LEFT JOIN和RIGHT JOIN关键字来执行的。首先先简单介绍这两种查询方法的语法。

左查询(LEFT JOIN)

在MySQL中,左查询(Left Join)是一种用于连接两个或多个表格的查询操作。左查询返回左表格中的所有行,并包括与右表格中匹配的行。

左查询是指将左边的表作为主要表,连接右边的表,并返回所有匹配的行。以下是左查询的语法:

SELECT 列名
FROM1
LEFT JOIN2 ON1.=2.;
  • 表1 和 表2 是要连接的两个表,其中 表1 是主要表。
  • 列名 是你想要获取的列,可以是从 表1 或者 表2 中的列,也可以是其他计算字段。
  • ON 后面的条件用于指定连接的条件,它们应该是两个表中相关列之间的相等比较。

右查询(RIGHT JOIN)

右查询是指将右边的表作为主要表,连接左边的表,并返回所有匹配的行。以下是右查询的语法:

SELECT 列名
FROM1
RIGHT JOIN2 ON1.=2.;

表2 是主要表,而 表1 是次要表。其他语法元素与左查询非常相似。

除此之外,MySQL中还提供了INNER JOIN和OUTER JOIN等不同类型的连接,它们也可以用于实现类似的功能。但是在我们实际使用中,LEFT JOIN和RIGHT JOIN是最常见的连接方式,能够满足一般的查询需求。

如果通过以上的简单叙述还不是很清楚,那么我们以一个案例来详细说明:

案例说明

下面我们通过一个案例,以学生表格和班级表格为例,演示如何使用左查询和右查询将学生表格和班级表格连接在一起:

学生表格,学生表格里面有学生id,姓名和班级id:

CREATE TABLE students (
student_id INT,
student_name VARCHAR(50),
class_id INT );

向学生表格中添加三条数据:

INSERT INTO students (student_id, student_name, class_id)
VALUES (1, '张三', 101),
       (2, '李四', 102),
       (3, '王五', 101);

然后创建班级表格:

CREATE TABLE classes (
    class_id INT,
    class_name VARCHAR(50)
);

向班级表格中添加两条数据:

INSERT INTO classes (class_id, class_name)
VALUES (101, '理科班'),
       (103, '文科班');

接着使用左查询进行连接:

SELECT students.student_id, students.student_name, classes.class_name
FROM students
LEFT JOIN classes
ON students.class_id = classes.class_id;

查询结果:

student_id | student_name | class_name

1 | 张三 | 理科班
2 | 李四 | NULL
3 | 王五 | 理科班

如上图所示,它是我们使用左查询连接了学生表格和班级表格。结果中包括了学生表格中的所有行,同时将与班级表格中匹配的班级信息添加到结果集中。如果没有匹配的班级记录,则显示为NULL

此外,左查询也可以使用LEFT OUTER JOIN进行表示,两者是等效的,只是关键字不同而已。

MySQL中的左查询允许我们返回左表格中的所有行,并且包括与右表格中匹配的行。这对于需要显示左表格的全部数据时非常有用。

同理,当我们使用右查询的代码实行时,会出现不一样的情况:

使用右查询进行连接:

SELECT students.student_id, students.student_name, classes.class_name
FROM students
RIGHT JOIN classes
ON students.class_id = classes.class_id;

查询结果:

student_id | student_name | class_name

1 | 张三 | 理科班
3 | 王五 | 理科班
NULL | NULL | 文科班

上述结果中,我们使用了右查询连接了学生表格和班级表格。结果中包括了班级表格中的所有行,同时将与学生表格中匹配的学生信息添加到结果集中。如果没有匹配的学生记录,则显示为NULL。

同时,右查询也可以使用RIGHT OUTER JOIN进行表示,两者是等效的,只是关键字不同而已。

总结来说,MySQL中的右查询允许我们返回右表格中的所有行,并且包括与左表格中匹配的行。这对于需要显示右表格的全部数据时非常有用。

文章到这里就先结束了,感兴趣的可以订阅专栏哈,后续会继续分享相关的知识点。

在这里插入图片描述

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

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

相关文章

LeetCode——从上到下打印二叉树 II

题目来源 剑指 Offer 32 - II. 从上到下打印二叉树 II - 力扣(LeetCode) 题目 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。 示例 给定二叉树:[3,9,20,null,null,15,7] 返回其层…

vuex2实现时间列表选择器

目录 一、效果展示 二、代码分析 2.1、区域确定与坐标获取 2.2、单个点击与一次性点击 一、效果展示 主要借助自定义指令实现。在表格的"td们"上面进行移动框选,有一次性框选和单个框选,去掉自定义指令里的clearTargetNodes()会连续td,连…

Hudi学习5:Hudi的helloworld-编译源码

hudi是使用java代码编写的 部署hudi 1. 下载源码 Download | Apache Hudi https://dlcdn.apache.org/hudi/0.13.1/hudi-0.13.1.src.tgz 2.编译 安装maven 首先要先有JDK java8以上 配置镜像源 执行编译 测试

Yolov5小目标性能提升方案介绍

目录 1.小目标检测介绍 1.1 小目标定义 1.2 难点 2.小目标难点解决方案 2.1注意力提升小目标检测精度 2.1.1 上下文信息CAM 2.1.2 ConvNeXt 2.1.3 ECVBlock 2.1.4 多头上下文集成(Context Aggregation)的广义构建模块 2.2 多头检测头 2.3 loss优化…

spring 在容器中一个bean依赖另一个bean 需要通过ref方式注入进去 通过构造器 或property

spring 在容器中一个bean依赖另一个bean 需要通过ref方式注入进去 通过构造器 或property

Go语言net模块TCP和UDP编程实践

任何一种语言TCP和UDP网络编程总是必须的,接下来就将go语言中使用net标准库进行TCP和UDP编程进行梳理总结。 目录 1.代码结构 2.TCP通信 3.UDP通信 4.TCP模拟HTTP协议通信 5.利用TCP扫描那些端口被占用 1.代码结构 2.TCP通信 server.go package mainimport …

【正点原子STM32连载】 第四十八章 内存管理实验 摘自【正点原子】STM32F103 战舰开发指南V1.2

1)实验平台:正点原子stm32f103战舰开发板V4 2)平台购买地址:https://detail.tmall.com/item.htm?id609294757420 3)全套实验源码手册视频下载地址: http://www.openedv.com/thread-340252-1-1.html# 第四…

全志V3S嵌入式驱动开发(spi-nand image制作)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】 上一篇文章,我们说到了spi-nor image的制作和输入。相比较spi-nor,spi-nand虽然在稳定性上面差一点,但是价格上面有很大的优势。举例来说,一般32M的spi-nor大约在6-7元左右,但…

Springboot链接Redis实现AOP防止重复提交

目录 安装redis Springboot链接Redis 1.创建springboot项目 如果spring boot启动报Error creating bean with name redisUtil/redisTemplate 2.新建application.yml配置 3.redis配置类-直接用 4.redis工具类-直接用 5.写Controller测试 6.启动、测试 整合AOP&#xff…

内网横线移动—WmiSmbCrackMapExecProxyChainsImpacket

内网横线移动—Wmi&Smb&CrackMapExec&ProxyChains&Impacket 1. 前置环境准备2. wmic介绍2.1. wmic操作演示2.1.1. 受控主机上线2.1.1.1. 内网存活探测2.1.1.2. 密码抓取 2.1.2. 横向移动2.1.2.1. 上传文件2.1.2.2. 文件上传目标主机2.1.2.3. 执行木马 2.2. wmi…

JAVA 安全-JWT 安全及预编译 CASE 注入等(40)

在各种语言脚本的环境下,也会产生一些新的漏洞,如果是java又能产生那些漏洞,思维导图里面常规漏洞之前都有; java的访问控制,jwt令牌(php几乎没有)组件安全,这些都是java特有的 #综…

C#核心知识回顾——3.继承构造、拆装箱、多态

1.继承中的构造函数: 特点: 当申明一个子类对象时 先执行父类的构造函数,再执行子类的构造函数注意!!: 1.父类的无参构造很重要 2.子类可以通过base关键字代表父类调用父类构造 public class Mot…

【单片机】STM32单片机,定时器的输入捕获,基于捕获的频率计,STM32F103

文章目录 简单介绍外部计数频率计TIM5 频率计 简单介绍 下面的定时器都具有输入捕获能力: 外部计数频率计 查看另一篇文章:https://qq742971636.blog.csdn.net/article/details/131471539 外部计数频率计的缺点:需要两个定时器配合&#x…

控制 显示、隐藏

1、使用 v-if < v-if"isShow"></> data(){ return:{ isShow:false } } if (concepts && concepts.length >0){ this.isShow nv.concepts.includes(snap) } 确认 数组中有某个 字段&#xff0c;用includes 有&…

Qt QGraphics导入背景图并绘制图形,画布移动、缩放、图形旋转等

前言 之前写过一篇博文《Qt鼠标拖动绘制基本几何图形》 &#xff0c;这是介绍使用QGraphic中利用鼠标事件实现基本几何图形的绘制&#xff0c;支持直线、矩形、圆形、椭圆&#xff0c;本次是在此基础上进行扩展&#xff0c;实现背景图导入&#xff0c;并在图片上进行几何图形绘…

现货白银行情实时行情与展望

现货白银作为低门槛、高收益的贵金属投资工具&#xff0c;因为交易时间自且没有涨跌幅限制而大受全球投资者追捧&#xff0c;它每天的实时行情走势中充满机会&#xff0c;投资者可结合技术和基本面分析手段&#xff0c;预测其未来的价格走势&#xff0c;在市场的波动中把握住获…

Go编写流量代理工具

目录 这是一个演示主要分为俩包&#xff1a;流程&#xff1a;逻辑&#xff1a;(端口随意&#xff0c;本地ssh为例)用法&#xff1a;文件地址&#xff1a;代码如下&#xff1a; 这是一个演示 代理本地HTTP服务 代理局域网SSH服务 其他的TCP服务没测试了 主要分为俩包&#x…

什么是DevOps? 什么是DORA?

1. 前言 对于搞云原生应用的同学&#xff0c;对于DevOps和DORA应该都不陌生。但对于传统应用程序开发的同学&#xff0c;经常被DevOps, Microservice, CICD, DORA这些新颖的名词搞得晕头转向。那么到底什么是DevOps? 什么是DORA呢&#xff1f; 2. 解析 2.1 DevOps DevOps并…

群晖NAS搭建WebDV服务手机ES文件浏览器远程访问

文章目录 1. 安装启用WebDAV2. 安装cpolar3. 配置公网访问地址4. 公网测试连接5. 固定连接公网地址 转载自cpolar极点云文章&#xff1a;群晖NAS搭建WebDAV服务手机ES文件浏览器远程访问 有时候我们想通过移动设备访问群晖NAS 中的文件,以满足特殊需求,我们在群辉中开启WebDav服…

支持刷机(OpenWrt)的路由器大全

2023年上半年最热门的刷机路由器当然是360T7、小米WR30U这两款&#xff0c;主要是性价比高&#xff0c;闲鱼100多搞定&#xff0c;支持刷OpenWrt、支持WiFi6&#xff0c;采用MTK798X系列处理器&#xff0c;性能强&#xff0c;轻松跑满千兆&#xff0c;如果你想追新&#xff0c;…