Mysql联表查询

关系型数据库设计的表一般都是一类信息一张表。当我们查询的信息来自于多个表时,除了使用刚才学的子查询可以实现,还可以使用联表查询,联表查询由于效率高于子查询,是更推荐的。联表查询就是在多张表之间建立一种联系,一种条件,通过这个条件,去每个表中筛选数据,最终得到正确的匹配数据。所以正确的联表条件才是关键。

如果没有联表条件,就拿不到正确的数据,拿到的是多个表之间的数据的任意组合,这是不正确的数据。

如股票没有联表条件,查询的结果就是所有数据的排列组合,这显然是不正确的,所以需要有联表条件

复制代码
SELECT stuname,assistant FROM studentinfo,classinfo;

1)内连接

指的是联表条件要在每个表中都能找到匹配的数据,才可以返回最终正确的结果,只要任意一张表中没有匹配的数据,就不会返回这次的结果。意味着,内连接会丢失一部分数据

语法:表1 inner join 表2 on 联表条件

另外一种语法:使用普通的查询语句,使用where指定连表条件,from后面直接把要连接的多个表写到一起,逗号分开

例如,查询学生姓名和班主任,但是数据在两张表中,这时可以通过联表查询解决这个问题,联表条件是班级号相同

复制代码
SELECT stuname,assistant 
FROM studentinfo 
INNER JOIN classinfo 
ON studentinfo.`classnum`=classinfo.`classnum`;
-- 下面是简写的语法,也是内连接
SELECT stuname,assistant FROM studentinfo,classinfo WHERE studentinfo.`classnum`=classinfo.`classnum`; 

2)外连接

外连接跟内连接相反,它不要求联表条件在每个表中都能匹配到数据,它只负责联表,按照联表条件将数据组合到一起,对于没有匹配到数据的表,在组合数据的时候,只能填NULL。存在以哪个表为主的问题,这个主表要看到它所有数据的匹配情况,包括每一条数据,即使这条数据跟其他表匹配不到结果,也要返回。这时看到的是主表的所有数据。

左外:

以左表为主表,跟其他表进行外连接,返回的结果中必须包括左表的每一条记录。

语法:表1 left join 表2 on 联表条件

复制代码
SELECT stuname,assistant 
FROM studentinfo 
LEFT JOIN classinfo 
ON studentinfo.`classnum`=classinfo.`classnum`;

右外:

以右表为主表,跟其他表进行外连接,返回的结果中必须包括右表的每一条记录。

语法:表1 right join 表2 on 联表条件

左外连接和右外连接的区别就是 以左表为主表,跟其他表进行外连接,返回的结果中必须包括左表的每一条记录,右外连接其本质和左外连接是相同的

相关推荐
2301_8223636033 分钟前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
Leo.yuan44 分钟前
经营分析会,该讲些什么?
大数据·数据库·数据分析
云飞扬1 小时前
浅谈数据访问层
数据库·bpm·数据库访问层
Amarantine、沐风倩✨2 小时前
一次线上性能事故的处理复盘:从 SQL 到扩容的工程化思路
java·数据库·sql·oracle
电商API&Tina2 小时前
乐天平台 (Rakuten) 数据采集指南
大数据·开发语言·数据库·oracle·json
l1t2 小时前
用SQL执行累计值汇总的几种方法
数据库·sql·postgresql·duckdb
踢足球09292 小时前
寒假打卡:2026-2-3
数据库
每次学一点2 小时前
【ZeroTier自研之路】planet的组成
服务器·网络·数据库
策知道3 小时前
2026年北京政府工作报告产业指标深度解析
大数据·数据库·人工智能·搜索引擎·政务
Traced back3 小时前
# C# WinForms 数据库清理系统基础知识与避坑指南
开发语言·数据库·c#