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

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

相关推荐
倔强的石头_1 小时前
关系数据库替换用金仓:数据迁移过程中的完整性与一致性风险
数据库
Elastic 中国社区官方博客1 小时前
使用 Groq 与 Elasticsearch 进行智能查询
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
穿过锁扣的风1 小时前
一文搞懂 SQL 五大分类:DQL/DML/DDL/DCL/TCL
数据库·microsoft·oracle
l1t1 小时前
DeepSeek总结的SNKV — 无查询处理器的 SQLite 键值存储
数据库·sqlite·kvstore
洛豳枭薰1 小时前
MySQL 梳理
数据库·mysql
九.九2 小时前
CANN 算子生态的底层安全与驱动依赖:固件校验与算子安全边界的强化
大数据·数据库·安全
蓝帆傲亦2 小时前
代码革命!我用Claude Code 3个月完成1年工作量,这些实战经验全给你
jvm·数据库·oracle
亓才孓2 小时前
[JDBC]事务
java·开发语言·数据库
PD我是你的真爱粉2 小时前
FastAPI使用tortoiseORM
数据库·fastapi
剩下了什么9 小时前
MySQL JSON_SET() 函数
数据库·mysql·json