【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表联合查询,把所有成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
相关推荐
运气好好的12 小时前
CSS如何实现响应式内边距自适应_利用vw单位动态调整
jvm·数据库·python
大江东去浪淘尽千古风流人物12 小时前
【UV-SLAM】eLSD/LBD 数据维度 UV-SLAM吸收借鉴
数据库·线性代数·oracle·矩阵·uv·augmented reality
小妖同学学AI12 小时前
抛弃传统数据库!Qdrant用Rust重写AI记忆,大模型知识库迎来性能革命!
数据库·人工智能·rust
m0_7411733312 小时前
如何实现SQL复杂计算触发器原子性_利用触发器事务控制
jvm·数据库·python
秋912 小时前
一键安装mysql8.0.46(附脚本)
数据库
abc123456sdggfd12 小时前
C#怎么使用gRPC双向流_C#如何实现高效RPC调用【进阶】
jvm·数据库·python
TeDi TIVE12 小时前
Linux下MySQL的简单使用
linux·mysql·adb
uElY ITER12 小时前
MySQL 中如何进行 SQL 调优
android·sql·mysql
qq_4142565713 小时前
Redis如何解决哨兵通知延迟问题_优化客户端连接池动态刷新拓扑的订阅监听机制
jvm·数据库·python
m0_6765443813 小时前
MySQL如何配置不同级别的事务锁_调整innodb_locks_unsafe_for_binlog
jvm·数据库·python