【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表联合查询,把所有成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
相关推荐
廿一夏6 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim7 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室8 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)8 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
敲个大西瓜8 小时前
Java项目常用数据归档方式
mysql
YOU OU9 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng10 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
kyriewen10 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室10 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿11 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试