MySQL连接查询补充与三表连查

前言

MySQL多表联查是指在一个查询语句中同时查询多个表,并根据表之间的关联条件进行数据的匹配和筛选。通过多表联查,我们可以获取到更丰富的数据信息,从而满足复杂的查询需求。先前了解了三种简单的连接查询方式,这里将进一步介绍更复杂的连接查询。

关于内连接、左连接、右连接介绍请参考:MySQL高级SQL语言常用查询与连接查询-CSDN博客

目录

一、外连接的其他使用

1. full [outer] join(全连接)

2. left join + where right.table is null

3. right join + where left.table is null

二、三表连查 

1. 概述

2. 格式 

3. 示例


一、外连接的其他使用

场景:

mysql> select * from class1;
+------+----------+
| id   | name     |
+------+----------+
|    1 | zhangsan |
|    2 | lisi     |
|    3 | wangwu   |
+------+----------+
mysql> select * from class2;
+------+------+
| id   | age  |
+------+------+
|    1 | 10   |
|    2 | 20   |
|    4 | 30   |
+------+------+

1. full [outer] join(全连接)

返回左表和右表中所有的行,如果某个表中的行在另一个表中没有匹配的行,则用NULL填充。它用于获取两个表中的所有数据,无论是否有匹配的行。

格式:

select 列名 from 表1 full join 表2 on 表1.列名 = 表2.列名;

示例:full join 在 mysql 支持的较少,可以用 left join union right join 模拟代替

mysql> select a.id aid,a.name,b.id bid,b.age from class1 a left join class2 b on a.id=b.id union select a.id aid,a.name,b.id bid,b.age from class1 a right join class2 b on a.id=b.id;
+------+----------+------+------+
| aid  | name     | bid  | age  |
+------+----------+------+------+
|    1 | zhangsan |    1 | 10   |
|    2 | lisi     |    2 | 20   |
|    3 | wangwu   | NULL | NULL |
| NULL | NULL     |    4 | 30   |
+------+----------+------+------+

2. left join + where right.table is null

表示对左连接后的结果进行过滤,只保留那些右表中没有匹配记录的行。即得到左表全部数据,去掉满足右表的共同区域。

格式:

select a.* from 表1 a left join 表2 b on a.相同字段 = b.相同字段 where b.相同字段 is null;

示例:

mysql> select a.* from class1 a left join class2 b  on a.id = b.id where b.id is null;
+------+--------+
| id   | name   |
+------+--------+
|    3 | wangwu |
+------+--------+

3. right join + where left.table is null

表示对右连接后的结果进行过滤,只保留那些左表中没有匹配记录的行。即得到右表全部数据,去掉满足左表的共同区域。

格式:

select b.* from 表1 a right join 表2 b on a.相同字段 = b.相同字段 where a.相同字段 is null;

示例:

mysql> select b.* from class1 a right join class2 b  on a.id = b.id where a.id is null;
+------+------+
| id   | age  |
+------+------+
|    4 | 30   |
+------+------+

二、三表连查 

1. 概述

在 MySQL 中进行三表连接查询是一种常见的数据库操作,用于检索多个表中相关数据的方法。三表连接允许我们同时连接三个表,通过指定连接条件来获取符合条件的数据。这种查询通常涉及使用 join 子句来连接表,常见的三种连接方式包括内连接、左连接和右连接。

2. 格式 

select 列名
from 表1
join 表2 om 表1.列名 = 表2.列名
join 表3 on 表2.列名 = 表3.列名
where 条件;

3. 示例

环境准备:

mysql> select * from t1;
+------+-------+
| id   | score |
+------+-------+
|    1 | 100   |
|    3 | 150   |
|    5 | 120   |
+------+-------+
mysql> select * from t2;
+------+----------+---------+
| id   | name     | classid |
+------+----------+---------+
|    1 | zhangsan |     111 |
|    2 | lisi     |     222 |
|    5 | wangwu   |     555 |
+------+----------+---------+
mysql> select * from t3;
+---------+-----------+
| classid | class     |
+---------+-----------+
|     111 | yinianji  |
|     444 | ernianji  |
|     555 | sannianji |
+---------+-----------+

目标:内连接查询,查找字段相同值,最后显示name、score、class信息

mysql> select b.name,a.score,c.class from t1 a inner join t2 b on a.id=b.id inner join t3 c on b.cllassid=c.classid;
+----------+-------+-----------+
| name     | score | class     |
+----------+-------+-----------+
| zhangsan | 100   | yinianji  |
| wangwu   | 120   | sannianji |
+----------+-------+-----------+

 左连接查询:

mysql> select b.name,a.score,c.class from t1 a left join t2 b on a.id=b.id left join t3 c on b.classid=c.classid;
+----------+-------+-----------+
| name     | score | class     |
+----------+-------+-----------+
| zhangsan | 100   | yinianji  |
| wangwu   | 120   | sannianji |
| NULL     | 150   | NULL      |
+----------+-------+-----------+

右连接查询: 

mysql> select b.name,a.score,c.class from t1 a right join t2 b on a.id=b.id right join t3 c on b.cllassid=c.classid;
+----------+-------+-----------+
| name     | score | class     |
+----------+-------+-----------+
| zhangsan | 100   | yinianji  |
| wangwu   | 120   | sannianji |
| NULL     | NULL  | ernianji  |
+----------+-------+-----------+

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

17.应用负载压力测试

早些点,下午题考,最近几年出现的少; 备考较为简单;历年真题相似度高; 主要议题: 1.负载压力测试概述 注意这些测试细微的差别; 负载测试和压力测试的方法比较相似,但是目的不同&a…

如何使用potplayer在公网环境访问内网群晖NAS中储存在webdav中的影视资源

🌈个人主页: Aileen_0v0 🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​💫个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-D7WJh3JaNVrLcj2b {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

臻奶惠无人售货机:新零售时代的便捷消费革命

臻奶惠无人售货机:新零售时代的便捷消费革命 在新零售的浪潮中,智能无人售货机作为一个创新的消费模式,已经成为距离消费者最近的便捷购物点之一。这种模式不仅能够满足居民对消费升级的需求,还能通过建立多样化和多层次的消费体…

2024年04月编程语言流行度排名

点击查看最新编程语言流行度排名(每月更新) 2024年04月编程语言流行度排名 编程语言流行度排名是通过分析在谷歌上搜索语言教程的频率而创建的 一门语言教程被搜索的次数越多,大家就会认为该语言越受欢迎。这是一个领先指标。原始数据来自…

MotionBuilder 脚本执行

目录 MediaPipe_Pose_in_MotionBuilder 你可以用以下几种方式执行你的脚本: MediaPipe_Pose_in_MotionBuilder https://github.com/Ndgt/MediaPipe_Pose_in_MotionBuilder/blob/main/PoseLandmark.py tcp通信 https://github.com/nils-soderman/motionbuilder-s…

银行业架构网络BIAN (Banking IndustryArchitecture Network)详细介绍

BIAN ( The Banking Industry Architecture Network) 是一个业界多方协作的非营利性组织,由全球领先银行、技术提供商、顾问和学者组成,定义了一个用以简化和标准化核心银行体系结构的银行技术框架。这一框架基于面向服务的架构 (SOA) 原则,银…

RabbitMQ安装及Springboot 集成RabbitMQ实现消息过期发送到死信队列

死信队列 RabbitMQ 的死信队列(Dead-Letter-Exchanges,简称 DLX)是一个强大的特性,它允许在消息在队列中无法被正常消费(例如,消息被拒绝并且没有设置重新入队,或者消息过期)时&…

微服务管理(完整)

前言: 分享一篇学微服务管理的过程 一,etcd入门 1,简介 1.1,etcd是什么 etcd是CoreOS团队于2013年6月发起的开源项目,它的目标是构建一个高可用的分布式键值(key-value)数据库。 官网上的一段描述: A…

Mac 怎么提高音频播放速度?

mac 怎么提高音频播放速度?在Mac上,有时我们可能需要加快音频文件的播放速度,比如加快听力材料的播放速度以提高效率,或者快速浏览录音文件等。幸运的是,Mac系统自带的音频播放器iTunes和QuickTime都提供了简单的方法来…

中科驭数DPU技术开放日秀“肌肉”:云原生网络、RDMA、安全加速、低延时网络等方案组团亮相

2024年3月29日,中科驭数以“DPU构建高性能云算力底座”为主题的线上技术开放日活动成功举办。在开放日上,中科驭数集中展现了其在低时延网络、云原生网络及智算中心网络三大关键场景下的技术成果与五大核心DPU解决方案,凸显了中科驭数在高性能…

HUAWEI 华为交换机 配置 Eth-Trunk 接口流量本地优先转发示例(堆叠)

组网需求 说明 S5720I-10X-PWH-SI-AC 和 S5720I-6X-PWH-SI-AC 不支持此配置。 如 图 3-23 所示,为了增加设备的容量采用设备堆叠技术,将 Switch3 和 Switch4通过专用的堆叠电缆链接起来,对外呈现为一台逻辑交换机。为了实现设备间的备份、…

C# WPF编程-Application类(生命周期、程序集资源、本地化)

C# WPF编程-Application类 应用程序的生命周期创建Application对象应用程序的关闭方式应用程序事件 Application类的任务显示初始界面处理命令行参数访问当前Application对象在窗口之间进行交互 程序集资源添加资源检索资源pack URI内容文件 本地化构建能够本地化的用户界面 每…

vue改名为威优易?

文章目录 vue改名为威优易? 祝大家愚人节快乐哇! 哈哈,大家愚人节快乐!看来我刚刚的“爆料”确实把大家吓了一跳,Vue.js要改名为“威优易”?这纯粹是官方在这个愚人节使者开的一个小小玩笑啦! …

R语言技能 | 不同数据类型的转换

原文链接:R语言技能 | 不同数据类型的转换 本期教程 写在前面 今天是4月份的第一天,再过2天后再一次迎来清明小假期。木鸡大家是否正常放假呢? 我们在使用R语言做数据分析时,会一直对数据进行不同类型的转换,有时候…

VSCode - 离线安装扩展python插件教程

1,下载插件 (1)首先使用浏览器打开 VSCode 插件市场link (2)进入插件主页,点击右侧的 Download Extension 链接,将离线安装包下载下来(文件后缀为 .vsix) 2,…

Windows基线安全检测-安全配置检测

Windows基线安全检测-安全配置检测 前言 Windows在生产环境中是使用最多的一个系统,大部分为客户端,少部分为服务端; 然而其实很多用户对windows系统不是很了解,安全配置更是如此; 因此我们安全人员要定期对员工的主…

心里健康(健康与生存)

你还认为 健康 是有个强壮的身体吗? 这样 肯定是错的 我们来说说 什么是健康与现代健康观 以及影响健康的因素 有哪些? 以及 健康对个人与社会的意义 首先 我们来看看 健康演变过程 公元 1000 年 Health 首次出现 它代表了 强壮 健全 完整等含义 健康 …

Qt中出现中文乱码的原因以及解决方法

Qt专栏:http://t.csdnimg.cn/C2SDN 目录 1.引言 2.原因分析 3.源文件的编码格式修改方法 4.程序内部使用的默认编码格式修改方法 5.QString转std::string的方法 6.总结 1.引言 在编写Qt程序的时候,或多或少都可能遇到用QString时候,明明…

【QT+QGIS跨平台编译】056:【pdal-dimbuilder+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

点击查看专栏目录 文章目录 一、pdal介绍二、dimbuilder介绍三、pdal下载四、文件分析五、pro文件六、编译实践七、生成Dimension.hpp八、生成pdal_features.hpp一、pdal介绍 PDAL(Point Data Abstraction Library)是一个开源库,用于处理点云数据的获取、过滤、转换、分析和…

iPhone设备中如何导出和分享应用程序崩溃日志的实用方法

​ 目录 如何在iPhone设备中查看崩溃日志 摘要 引言 导致iPhone设备崩溃的主要原因是什么? 使用克魔助手查看iPhone设备中的崩溃日志 奔溃日志分析 总结 摘要 本文介绍了如何在iPhone设备中查看崩溃日志,以便调查崩溃的原因。我们将展示三种不同的…