MySQL多表连接查询详解
目录
- 多表连接查询
- 内连接
- 左连接
- 右连接
- 子查询
- 总结
多表连接查询 表与表之间的连接分为内连接和外连接
- 内连接:仅选出两张表互相匹配的记录
- 外连接:既包括两张表匹配的记录,也包括不匹配的记录,同时外连接又分为左外连接(左连接)和右外连接(右连接)
内连接
首先准备两张表
学生student表
文章图片
分数score表
【MySQL多表连接查询详解】
文章图片
内连接:在每个表中找出符合条件的共有记录
查询student表中的学生姓名和分数
第一种写法:只使用where
select a.s_name, b.s_score from student a,score b where a.s_id = b.s_id;
第二种写法:join … on…
select a.s_name, b.s_score from student a join score b on a.s_id = b.s_id
第三种写法:inner join … on…
select a.s_name, b.s_score from student a inner join score b on a.s_id = b.s_id
文章图片
左连接
左连接:根据左表的记录,在被连接的右表中找出符合条件的记录与之匹配,如果找不到与左表匹配的,用null表示
第一种写法:left join … on …
select a.s_name,b.s_score from student a left join score b on a.s_id = b.s_id
第二种写法:left outer join … on …
select a.s_name,b.s_score from student a left outer join score b on a.s_id = b.s_id
文章图片
右连接
**右连接:**根据右表的记录,在被连接的左表中找出符合条件的记录与之匹配,如果找不到匹配的,用null表示
第一种写法:right join … on …
select a.s_name,b.s_score from student a right join score b on a.s_id = b.s_id;
第二种写法:right outer join … on …
select a.s_name,b.s_score from student a right outer join score b on a.s_id = b.s_id;
文章图片
子查询 子查询:是多表连接查询的一种实现方式,在一个select语句的from子句或where子句中嵌套了另一个select语句,外层的select查询语句成为主查询,换句话将就是WHERE或FORM中的查询语句称为子查询
WHERE子句中的子查询:子查询返回的值作为主查询的查询条件
FROM子句中的子查询:子查询返回的是一张虚拟的表,主查询从该查询从临时表查询出满足的条件
总结 本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复
- Android|Android BLE蓝牙连接异常处理
- mysql|InnoDB数据页结构
- mysql中视图事务索引与权限管理
- MYSQL主从同步的实现
- MySQL数据库的基本操作
- springboot整合数据库连接池-->druid