【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表联合查询,把所有成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
相关推荐
倔强的石头_19 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端