连接表「INNER JOIN」「LEFT JOIN」「RIGHT JOIN」+ 多表查询

news2025/1/12 19:49:58

目录

  • 表关联执行顺序 及 原理
    • 第一步、做笛卡尔积
    • 第二步:根据ON后的连接条件筛选笛卡尔积的结果
    • 第三步:补充左表(LEFT JOIN)或右表(RIGHT JOIN)不满足连接条件的数据(INNER JOIN内关联时无此步骤)
    • 第四步:根据WHERE后的过滤条件筛选第三步的结果
  • 什么是笛卡尔积
  • 交叉连接`CROSS JOIN`
  • 内连接`INNER JOIN`
  • 全外连接`FULL OUTER JOIN`
  • 左外连接`LEFT OUTER JOIN`
  • 右外连接`RIGHT OUTER JOIN`
  • LEFT JOIN与INNER JOIN 对比下
  • WHERE与ON 在 表关联中使用后的区别
  • 多表连接
  • 总结

本文会先讲解 表关联如何执行的,然后在后边会详细讲解 一些词汇的含义以及各种类型的表关联

表关联执行顺序 及 原理

如下代码:

SELECT * FROM student a
LEFT JOIN teacher b
ON a.teacher_id = b.teacher_id   # 连接条件(关联条件)
WHERE a.score > 90;              # 过滤条件

Alt

第一步:参与连接的两个表做笛卡尔积;
第二步:根据ON后的连接条件筛选笛卡尔积的结果;
第三步:补充左表(LEFT JOIN)或右表(RIGHT JOIN)不满足连接条件的数据(INNER JOIN内关联时无此步骤) ;
第四步:根据WHERE后的过滤条件筛选第三步的结果;

表关联的时候,严格按照上方的 执行步骤即可。 第二步和第三步一定不能搞混

第一步、做笛卡尔积

请添加图片描述

第二步:根据ON后的连接条件筛选笛卡尔积的结果

红色⭐️代表的是筛选出来的数据
请添加图片描述

第三步:补充左表(LEFT JOIN)或右表(RIGHT JOIN)不满足连接条件的数据(INNER JOIN内关联时无此步骤)

请添加图片描述

第四步:根据WHERE后的过滤条件筛选第三步的结果

请添加图片描述

什么是笛卡尔积

请添加图片描述

交叉连接CROSS JOIN

使用CROSS JOIN实现两个集合的笛卡尔积。

请添加图片描述

内连接INNER JOIN

student表
请添加图片描述

teacher表
请添加图片描述

如何同时查询出学生编号、学生姓名、老师编号、老师姓名?

select * from student a INNER JOIN teacher b 
ON a.teacher_id = b.teacher_id;

实现流程如下:
先笛卡尔集、然后根据连接条件 筛选
(红⭐️代表筛选后的数据)
请添加图片描述

筛选后数据如下:
请添加图片描述

如何返回这两张表里,老师编号不相同的记录?

select * from student a INNER JOIN teacher b 
ON a.teacher_id <> b.teacher_id;

请添加图片描述

全外连接FULL OUTER JOIN

如何同时查询出学生编号、学生姓名、老师编号、老师姓名?

请添加图片描述

请添加图片描述

左外连接LEFT OUTER JOIN

OUTER 关键字可以省略

如何同时查询出学生编号、学生姓名、老师编号、老师姓名?

select * from student a LEFT JOIN teacher b 
ON a.teacher_id = b.teacher_id;

请添加图片描述

右外连接RIGHT OUTER JOIN

OUTER 关键字可以省略

如何同时查询出学生编号、学生姓名、老师编号、老师姓名?

select * from student a RIGHT JOIN teacher b 
ON a.teacher_id = b.teacher_id;

请添加图片描述

LEFT JOIN与INNER JOIN 对比下

对比下 left 和 inner 查询出的数据区别

SELECT * FROM student a 
INNER JOIN teacher b 
ON a.teacher_id = b.teacher_id;

SELECT * FROM student a 
LEFT JOIN teacher b 
ON a.teacher_id = b.teacher_id;

红色 ⭐️ 代表 inner查询出的数据
黄色 ⭐️ 代表 left查询出的数据
请添加图片描述

WHERE与ON 在 表关联中使用后的区别

这里需要严格按照 表关联的执行顺序走代码,那么就不会出错

对比下方 SQL跑出的数据是否一致 INNER JOIN

SELECT * FROM student a 
INNER JOIN teacher b 
ON a.teacher_id = b.teacher_id
AND a.score>90;
SELECT * FROM student a 
INNER JOIN teacher b 
ON a.teacher_id = b.teacher_id
WHERE a.score>90;

结果如下:
红色 ⭐️ 代表使用 and 查询出的数据
黄色 ⭐️ 代表 使用 where 查询出的数据
请添加图片描述

对比下方 SQL跑出的数据是否一致 LEFT JOIN

SELECT * FROM student a 
LEFT JOIN teacher b 
ON a.teacher_id = b.teacher_id
AND a.score>90;
SELECT * FROM student a 
LEFT JOIN teacher b 
ON a.teacher_id = b.teacher_id
WHERE a.score>90;

结果如下:
红色 ⭐️ 代表使用 and 查询出的数据
黄色 ⭐️ 代表 使用 where 查询出的数据
请添加图片描述

多表连接

SELECT a.student_id,a.student_name,
a.teacher_id,b.teacher_name,
a.class_id,c.class_name
FROM student a 
LEFT JOIN teacher b 
ON a.teacher_id = b.teacher_id
LEFT JOIN class c
ON a.class_id = c.class_id;

第一步:a表与b表做LEFT JOIN;
第二步:a表与b表LEFT JOIN的结果,再与c表做LEFT JOIN;

多表连接,就是第一张表与后面的表依次连接,重复执行表连接的步骤而已!

表关联时,首先需要确认的一点,就是关联条件字段在关联表中是不是唯一。
在绝大多数的情况下,关联条件字段都是关联表中的主键或能唯一确定一条
记录的字段。如果不是,很可能是SQL的关联条件有问题,需要仔细确认是
否与需求相符。

总结

请添加图片描述

在这里插入图片描述

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

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

相关文章

CMOS门电路总结

目录 MOS管&#xff1a; CMOS组成的常见门电路 反相器&#xff08;非门&#xff09;&#xff1a; 与非门 或非门 OD门 三态门 MOS管简介&#xff1a; > NMOS: 漏极&#xff08;D&#xff09;入&#xff0c;源极&#xff08;S&#xff09;出&#xff0c;栅极(G)加正电压…

【MyBatis】级联处理、association、collection、分布查询(详细模板,可直接套用)

目录 示例 一、处理“多对一”映射关系 1.1、级联查询 1.2、association 1.3、分步查询 二、处理“一对多”映射关系 2.1、collection 2.2、分步查询 示例 例如&#xff1a;员工与部门表 员工&#xff1a; 部门&#xff1a; 解释&#xff1a; 两张表通过dept_id联系起来…

ubuntu22.04安装MySQL、Hive及Hive连接MySQL操作

前言 这篇文章主要讲述的是ubuntu22.04上数据仓库Hive的安装和使用 正文 建议按照文章实践前稍微通读下全文 安装MySQL服务端和客户端 相关命令&#xff1a; sudo apt-get install mysql-server sudo apt-get install mysql-client 修改mysql的配置文件 在终端中输入…

手撕LRU缓存

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类&#xff1a; LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&#xff0c;则返回关键字的值&#xff0c;否则返回 -…

python虚拟环境的概念,操作(pycharm为例)

1.在PyCharm中创建python项目时&#xff0c;需要配置python的运行环境&#xff0c;除了使用系统现有环境以外&#xff0c;还可以创建虚拟环境。 2.虚拟环境的创建是因为在实际开发中需要同期用到不同版本的python解释器&#xff0c;不同的第三方库以及同一个第三方库的不同版本…

牛客网 字符串通配符

做题链接&#xff1a;字符串通配符__牛客网 (nowcoder.com)要求&#xff1a;实现如下2个通配符(不区分大小写)&#xff1a; * &#xff1a;匹配0个或以上的字符&#xff08;注&#xff1a;能被*和?匹配的字符仅由英文字母和数字0到9组成&#xff0c;下同&#xff09;&#…

【回看2022 展望2023】一个普通大学生的2022回忆录

目录 一、前言 二、回望2022 2022年1月 2022年2月 2022年3月 2022年4月5月6月7月8月 2022年9月 2022年10月 2022年11月 2022年12月 三、总结与期望 结语 期望 一、前言 虽然我在csdn上已经有2年的码龄了&#xff0c;但我是从2021年4月才开始写我的第一篇博客。其实从学…

Cache实现

Cache&#xff08;S,E,B,m&#xff09;&#xff1a; S&#xff1a;每个set包含一个或者多个cache line&#xff08;高速缓冲行&#xff09; cache line&#xff1a;分别包含有效位&#xff08;valid&#xff09;、标记&#xff08;tag&#xff09;、数据块&#xff08;cache b…

机器学习中的数学原理——感知机模型

这个专栏主要是用来分享一下我在机器学习中的学习笔记及一些感悟&#xff0c;也希望对你的学习有帮助哦&#xff01;感兴趣的小伙伴欢迎私信或者评论区留言&#xff01;这一篇就更新一下《白话机器学习中的数学——感知机》&#xff01; 目录 一、什么是感知机 二、模型分析…

HDLC、ppp、MGRE实验(1.1)

1、首先为每个路由器的每个接口配置ip r1&#xff1a; [r1]interface Serial 4/0/0 [r1-Serial4/0/0]ip address 12.1.1.1 24 [r1-Serial4/0/0]int gi 0/0/0 [r1-GigabitEthernet0/0/0]ip add 192.168.1.1 24 r2&#xff1a; [r2-Serial4/0/0]ip add 12.1.1.2 24 [r2-Seria…

二十三、shiro安全框架详解(一)

一、 权限概述 1. 什么是权限 权限管理&#xff0c;一般指根据系统设置的安全策略或者安全规则&#xff0c;用户可以访问而且只能访问自己被授权的资源&#xff0c;不多不少。权限管理几乎出现在任何系统里面&#xff0c;只要有用户和密码的系统。 权限管理在系统中一般分为…

手把手代码实现五级流水线CPU——第三篇:流水线控制逻辑

系列文章目录 第一篇&#xff1a;初级顺序流水线 第二篇&#xff1a;分支预测流水线 文章目录系列文章目录一、控制逻辑二、具体操作1.判断暂停2.控制冒险3.跳转问题4.实现代码一、控制逻辑 通过暂停和插入气泡来动态调整流水线的状态 二、具体操作 1.判断暂停 识别&#x…

MySQL高级 索引【索引使用索引设计原则】

目录 1&#xff1a;索引使用 1.1&#xff1a;验证索引效率 1.2&#xff1a;最左前缀法则 1.3&#xff1a;范围查询&#xff08;存在索引失效的情况&#xff09; 1.4&#xff1a;索引失效情况 1.4.1&#xff1a;索引列运算&#xff08;索引会失效&#xff09; 1.4.2&…

第三十五讲:无线局域网基础知识

1. IEEE 802.11协议 802.11无线标准家族包括802.11a/b/g/n/ac五个标准理论上可以提供高达每秒1Gbit的数据传输能力标准定义了如何使用免授权2.4 GHz 和 5GHz 频带的电磁波进行信号传输。 802.11无线标准家族 802.11a 802.11b 802.11g 802.11n 802.11ac 工作频段 5GHz 2…

servelt的cookie操作

Cookie对象 Cookie是浏览器提供的一种技术&#xff0c;通过服务器的程序能将一些只须保存在客户端&#xff0c;或者在客户端进行处理的数据&#xff0c;放在本地的计算机上&#xff0c;不需要通过网络传输&#xff0c;因而提高网页处理的效率&#xff0c;并且能够减少服务器的…

Allegro如果通过CNS Show命令查看走线的阻抗操作指导

Allegro如果通过CNS Show命令查看走线的阻抗操作指导 Allegro可以通过CNS show的命令快速查看走线的阻抗,省去通过规则管理器查看的时间,如下图 具体操作如下 选择Display命令选择Constraint

使用资源绑定器获取属性配置文件中的内容(读取属性配置文件最简单的方法)

package com.javase.reflect;import java.util.ResourceBundle;/*** java.util包下提供了一个资源绑定器&#xff0c;便于获取属性配置文件中的内容&#xff0c;使用这种方式的时候&#xff0c;* 属性配置文件必须放在类路径下。该文件的文件名必须是 "*.properties&…

2022年度总结|我的CSDN成长历程

作者简介&#xff1a;一名在校云计算网络运维学生、每天分享网络运维的学习经验、和学习笔记。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 周榜第一&#xff0c;诚信互投 我正在参加年度博客之星评选&#xff0c;麻烦…

Leetcode:150. 逆波兰表达式求值(C++)

目录 问题描述&#xff1a; 实现代码和解析&#xff1a; 原理思路&#xff1a; 问题描述&#xff1a; 给你一个字符串数组 tokens &#xff0c;表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 示例 1&#xff1a; 输入&a…

Selenium用法详解【从入门到实战】【JAVA爬虫】

目录 简介 selenium安装 java使用 浏览器控制 修改窗口大小 窗口最大化 窗口全屏显示 浏览器前进&后退 浏览器刷新 浏览器打开新标签页 浏览器窗口切换 关闭标签页 关闭浏览器 浏览器页面截图 其他操作 简介 Selenium是一个用于Web应用程序测试的工具。Seleniu…