MySQL数据操作与查询- 连接查询


一、引入

1、为什么需要使用连接查询?
查询信息的来源如果来自多张表,则必须对这些表进行连接查询。
2、连接查询的分类
内连接和外连接。


二、内连接
1、概述
将两张表的记录组合在一起,产生一个新的结果。
(1)具体实现:将表1的每一行和表2的每一行进行比较,找出满足条件的组合。
(2)分类:交叉连接(笛卡尔积)、 相等连接 、自然连接。
2、交叉连接(笛卡尔积)
返回两张表所有的组合情况。
语法:
1 select 字段列表 from 表 1 , 表 2
【实例】 求出学生表和课程表的笛卡尔积。
【解答】

复制代码
1 select * from student,course


【说明】
学生表有4条记录,课程表有6条记录,所有的组合方式共有4*6=24种。
3、 相等连接

返回满足条件的组合情况。
语法:
1 select 字段列表
2 from 表名 1
3 [ inner ] join 表名 2 on 表名 1. 字段名 1 = 表名 2. 字段名 2
4 where 条件表达式
【说明】
inner可以省略不写。
【实例】 查询得到学生的所有成绩。
【解答】

复制代码
1 select *
2 from student
3 inner join score on student.student_id=score.student_id


【实例】 查询得到课程的所有成绩,显示的内容包括:课程号、课程名、成绩
【解答】

复制代码
1 select c.course_id 课程号,
2 name as 课程名,
3 score 成绩
4 from course c ‐‐ 给course表取个别名c
5 join score sc on c.course_id=sc.course_id


4、自然连接

实现过程:将两张表的所有 名称相同的列 都将被比较,并且在结果集中把 重复的列去掉 , 结果集
中两张表中名称相同的列仅出现一次。而普通的内连接并不去掉重复的列。
语法:
1 select 字段列表 from 表名 1 natural join 表名 2
【实例】 使用自然连接将学生表和成绩表连接起来。
【解答】

复制代码
1 select * from student natural join score


5、三表连接查询

语法:
1 select 字段列表
2 from 表名 1
3 join 表名 2 on 表名 1. 字段名 1 = 表名 2. 字段名 2
4 join 表名 3 on 表名 2. 字段名 3 = 表名 3. 字段名 4
5 where 条件表达式
【实例】 查询得到每位学生各门课程的成绩。显示内容包括:学号、姓名、课程名、成
绩。
【解答】

复制代码
1 select s.student_id 学号,
2 s.name 姓名,
3 c.name 课程名,
4 score 成绩
5 from student s
6 join score sc on s.student_id=sc.student_id
7 join course c on c.course_id=sc.course_id


【实例】 查询得到修读了"HTML5网页设计"的所有学生信息,显示内容包括:学号、姓
名。
【解答】

复制代码
1 select s.student_id 学号,
2 s.name 姓名
3 from student s
4 join score sc on s.student_id=sc.student_id
5 join course c on c.course_id=sc.course_id
6 where c.name='HTML5网页设计'


三、外连接

在内连接查询中,只有满足连接条件的记录才能出现在查询结果中。 如果希望不满足连接条件
的记录也在查询结果中出现,这时需要使用 外连接 查询。
分类:左连接和右连接。
1、左外连接(left join)
结果集包括 左表的所有记录 和右表中满足连接条件的记录,结果集中那些不符合连接条件的来源于
右表的列值为 null。
1 select 字段列表
2 from 表名 1
3 left join 表名 2 on 表名 1. 字段名 1 = 表名 2. 字段名 2
【实例】 使用"左外连接"查询得到学生的所有成绩。
【解答】

复制代码
1 select *
2 from student s
3 left join score sc on s.student_id=sc.student_id


2、右外连接(right join)

结果集包括 右表的所有记录 和左表中满足连接条件的记录,结果集中那些不符合连接条件的来源于
左表的列值为 null。
1 select 字段列表
2 from 表名 1
3 right join 表名 2 on 表名 1. 字段名 1 = 表名 2. 字段名 2
【实例】 使用"右外连接"查询得到课程的所有成绩。
【解答】

复制代码
1 select *
2 from score sc
3 right join course c on c.course_id=sc.course_id
相关推荐
一只笨猫猫1 小时前
MySQL中InnoDB存储引擎底层原理与MySQL日志机制深入解析
数据库·mysql
苏格拉没有底_coder1 小时前
Redis+Kafka实现动态延时任务
数据库·redis·kafka
江畔独步1 小时前
Doris与DS结合实现MySQL侧的Upsert功能
数据仓库·mysql·doris·upsert
hymuuuu1 小时前
【源码】研学报名小程序开发功能分析案例
mysql·php·需求分析
Detachym2 小时前
CentOS7下MySQL8.0的安装到基本操作
大数据·mysql·linux学习·学习日志
键盘歌唱家2 小时前
mysql索引失效
android·数据库·mysql
neoooo3 小时前
🎯 深入理解:JOIN 中 ON vs WHERE 条件差异
java·后端·mysql
想你依然心痛3 小时前
MySQL数据库:关系型数据库的基石
数据库·mysql
hweiyu003 小时前
MySQL视图介绍
数据库·mysql
海天瑞声AI4 小时前
六月上新!多语种正则/逆正则数据集、5000小时中文双工数据集、经典人物IP语音合成数据集……
数据库·人工智能·自然语言处理·语音识别