【MySQL】表的内连和外连

思维导图

学习目标

表的连接分为内连和外连。

一、内连接

1.1 内连接的概念

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

1.2 内连接的语法

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

1.3 内连接的一些基本案例

  • 显示SMITH的名字和部门名称(有两种写法)
cpp 复制代码
// 前面的写法
select * from emp, dept where emp.deptno = dept.deptno and ename = 'SMITH';
// 用标准的内连接写法
select * from emp inner join dept on emp.deptno = dept.deptno and ename  = 'SMITH';

二、外连接

2.1 左外连接

2.1.1 概念

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

2.1.2 语法

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

2.1.3 一些基本案例

  • 建立两张表
cpp 复制代码
create table stu (id int, name varchar(30)); -- 学生表
insert into stu values(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');
create table exam (id int, grade int); -- 成绩表
insert into exam values(1, 56),(2,76),(11, 8);
  • 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来

2.2 右外连接

2.2.1 概念

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

2.2.2 语法

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

2.2.3 一些基本案例

  • 对stu表和exam表联合查询,把所有成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
相关推荐
婪苏(Python学习ing)15 分钟前
MySQL 与 Redis 基础入门:从安装到核心操作
数据库
幻灭行度1 小时前
通过redis_exporter监控redis cluster
数据库·redis·缓存
Wang's Blog1 小时前
Nestjs框架: 基于Mongodb的多租户功能集成和优化
数据库·mongodb·多租户
Edingbrugh.南空1 小时前
Aerospike架构深度解析:打造web级分布式应用的理想数据库
数据库·架构
Cxzzzzzzzzzz3 小时前
数据库索引详解:原理、设计原则与应用场景
数据库·mysql
Alla T3 小时前
【通识】数据库
数据库·oracle
烙印6013 小时前
MySQL的底层原理--InnoDB数据页结构
java·数据库·mysql
betazhou4 小时前
SQL server 2019删除重建用户
数据库·sql server
MickeyCV5 小时前
MySQL数据库本地迁移到云端完整教程
服务器·数据库·mysql·oracle
IT邦德5 小时前
OGG同步Oracle到Kafka不停库,全量加增量
数据库·oracle·kafka