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 联表条件

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

相关推荐
-SGlow-1 小时前
MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)
linux·运维·服务器·数据库·mysql
明月5662 小时前
Oracle 误删数据恢复
数据库·oracle
♡喜欢做梦4 小时前
【MySQL】深入浅出事务:保证数据一致性的核心武器
数据库·mysql
遇见你的雩风4 小时前
MySQL的认识与基本操作
数据库·mysql
dblens 数据库管理和开发工具4 小时前
MySQL新增字段DDL:锁表全解析、避坑指南与实战案例
数据库·mysql·dblens·dblens mysql·数据库连接管理
weixin_419658314 小时前
MySQL的基础操作
数据库·mysql
不辉放弃5 小时前
ZooKeeper 是什么?
数据库·大数据开发
Goona_5 小时前
拒绝SQL恐惧:用Python+pyqt打造任意Excel数据库查询系统
数据库·python·sql·excel·pyqt
程序员编程指南6 小时前
Qt 数据库连接池实现与管理
c语言·数据库·c++·qt·oracle
幼儿园老大*8 小时前
数据中心-时序数据库InfluxDB
数据库·时序数据库