MySQL表的内外连接

MySQL表的内外连接

表的内外连接是通过 join ... on 关键字,对两个表形成的笛卡儿积进行筛选。内连接和外连接都是从多个表中检索信息,它们的本质差别在于如何显示没有匹配记录的数据。

1. 表的设计

mysql 复制代码
create table students(
	id int auto_increment primary key,
	name varchar(10),
	gender enum('男','女')
);

create table scores(
	id int,
    chinese tinyint,
    math tinyint,
    english tinyint,
    foreign key (id) references students(id)
);
mysql 复制代码
insert into students (name, gender) values ('张伟', '男');
insert into students (name, gender) values ('王芳', '女');
insert into students (name, gender) values ('李娜', '女');
insert into students (name, gender) values ('刘洋', '男');
insert into students (name, gender) values ('陈杰', '男');
insert into students (name, gender) values ('赵敏', '女');
insert into students (name, gender) values ('孙强', '男');
insert into students (name, gender) values ('周静', '女');
insert into students (name, gender) values ('吴磊', '男');
insert into students (name, gender) values ('郑丽', '女');

insert into scores (id, chinese, math, english) values (1, 85, 90, 78);
insert into scores (id, chinese, math, english) values (2, null, 88, 95);
insert into scores (id, chinese, math, english) values (3, 76, null, 80);
insert into scores (id, chinese, math, english) values (4, 88, 76, null);
insert into scores (id, chinese, math, english) values (5, null, null, null);
-- 注意只有前5号有成绩记录
insert into scores (id, chinese, math, english) values (null, 89, 87, 90);
insert into scores (id, chinese, math, english) values (null, 76, 81, 79);

2. 内连接

使用内连接查询两个表中的数据时,没有匹配连接条件的记录会被过滤 。在实际开发中使用最多的连接方法就是内连接,在复合查询文档中,虽然没有使用 inner join ... on ,但实际它们也都属于内连接。

语法:

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

显示学生的信息和成绩

数据库中只有前五个学生有成绩记录,所以内连接只会显示五条记录,没有成绩记录的学生自动过滤。

mysql 复制代码
select students.id,name,gender,chinese,math,english from students inner join scores on students.id = scores.id;

3. 外连接

外连接分为左外连接右外连接。左外连接允许左表的数据与右表的数据没有匹配,并显示出来,但右表与左表没有匹配则过滤掉,右外连接反之。

3.1 左外连接

使用左外连接显示学生的信息和成绩

数据库中只有前五个学生有成绩记录,后五个学生的成绩记录则全为 NULL

mysql 复制代码
select students.id,name,gender,chinese,math,english from students left join scores on students.id = scores.id;

3.2 右外连接

使用左外连接显示学生的信息和成绩

数据库中有两条成绩记录没有匹配的学生 id,故右外连接会显示这两条记录。

mysql 复制代码
select students.id,name,gender,chinese,math,english from students right join scores on students.id = scores.id;
相关推荐
用户094 分钟前
停止滥用 Dispatchers.IO:Kotlin 协程调度器的深度陷阱与优化实战
android·面试·kotlin
峥嵘life5 分钟前
Android16 adb投屏工具Scrcpy介绍
android·开发语言·python·学习·web安全·adb
千里码aicood11 分钟前
springboot+vue心理健康服务小程序(源码+文档+调试+基础修改+答疑)
数据库·vue.js·spring boot
麦兜*23 分钟前
Redis高可用架构设计:主从复制、哨兵、Cluster集群模式深度对比
java·数据库·spring boot·redis·spring·spring cloud·缓存
王嘉俊92525 分钟前
Redis 入门:高效缓存与数据存储的利器
java·数据库·redis·后端·spring·缓存·springboot
王维28 分钟前
【shardingsphere-jdbc】分表实践
java·数据库
遇见你的那天1 小时前
反编译查看源码
android
xxy.c1 小时前
基于IMX6ULL芯片--I2C总线简单应用
数据库·mongodb
cookqq1 小时前
MongoDB源码分析慢日志:从配置到实现的完整解析
数据库·mongodb·nosql·慢日志
8K超高清1 小时前
汇世界迎全运 广州国际社区运动嘉年华举行,BOSMA博冠现场展示并分享与科技全运的故事
运维·服务器·网络·数据库·人工智能·科技