Linux下学【MySQL】表的连接(inner join、left join、right join)(简单试题理解版)


每日激励:"不设限和自我肯定的心态:I can do all things。 --- Stephen Curry"
**绪论​:
本章我将结承接上文的多表查询,主要讲到内连接和外连接(左外连接 + 右外连接)其中的内连接本质就是多表查询中的使用 笛卡尔积查询 + where 语句的筛选出正确有效的数据,此处相当于给了一个较为官方的连接多表的方法,以及补充常用到的左外连接和右外连接,下一章将带你领略MySQL底层存表的具体方法(索引),敬请期待~
若有看不懂如何登录Linux中的MySQL来执行具体代码的或者不知道如何创建表等一些列MySQL基础的的请看---》MySQL专栏(文章平均94分)

早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。**


表的内连和外连

在笛卡尔积中本质和内连接很像,笛卡尔加需要一个where判断两表中的相同部分进行过滤掉没用的数据

1. 内连接

内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。

语法:

sql 复制代码
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

内连接实操:显示SMITH的名字和部门名称:

数据所需要的两表:

  • 使用之前直接合并两张表笛卡尔积的方法 + where过滤:
  • 使用现在内连接的方法(他们本质是等价的只不过这种写更加的正式,逻辑更清楚)

    后面还能用where:

2. 外连接

2.1左外连接

如果联合查询,左侧的表完全显示我们就说是左外连接

语法:

sql 复制代码
select 字段名 from 表名1 left join 表名2 on 连接条件

左外连接实操:查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来

需要的两张表:

  1. stu:
  2. exam:

    其中因为有些同学没有成绩但也要显示出学生信息那么学习信息需要左外连接(始终存在)

2.1右外连接

相同:如果联合查询,右侧的表完全显示我们就说是右外连接,就不过诉了

语法:

sql 复制代码
select 字段 from 表名1 right join 表名2 on 连接条件;

本章完。预知后事如何,暂听下回分解。

如果有任何问题欢迎讨论哈!

如果觉得这篇文章对你有所帮助的话点点赞吧!

持续更新大量MySQL细致内容,早关注不迷路。

相关推荐
平生不喜凡桃李37 分钟前
Linux网络层:IP
linux·运维·tcp/ip
凸头1 小时前
MySQL 的四种 Binlog 日志处理工具:Canal、Maxwell、Databus和 阿里云 DTS
数据库·mysql·阿里云
观测云1 小时前
阿里云 RDS MySQL 可观测性最佳实践
mysql·阿里云·云计算
塔能物联运维1 小时前
物联网设备运维中的自动化合规性检查与策略执行机制
java·运维·物联网·struts·自动化
阿方索1 小时前
虚拟化技术实践指南:KVM 与 VMware ESXi 部署全流程
linux·运维·服务器
PellyKoo1 小时前
Docker容器中中文文件名显示乱码问题完美解决方案
运维·docker·容器
YouEmbedded1 小时前
解码Linux文件IO之库的制作与应用
linux·动态库·静态库
野犬寒鸦2 小时前
从零起步学习MySQL || 第八章:索引深入理解及高级运用(结合常见优化问题讲解)
java·服务器·数据库·后端·mysql
Sam_Deep_Thinking2 小时前
为超过10亿条记录的订单表新增字段
mysql
奥尔特星云大使2 小时前
Docker 拉取 MySQL 5.7 镜像、启动容器并进入 MySQL
数据库·mysql·docker·容器