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

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

相关推荐
等....3 小时前
Minio使用
数据库
win x4 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
迷枫7125 小时前
DM8 数据库安装实战:从零搭建达梦数据库环境(附全套工具链接)
数据库
XDHCOM5 小时前
PostgreSQL 25001: active_sql_transaction 报错原因分析,故障修复步骤详解,远程处理解决方案
数据库·sql·postgresql
卤炖阑尾炎6 小时前
PostgreSQL 日常运维全指南:从基础操作到备份恢复
运维·数据库·postgresql
daad7777 小时前
wifi_note
运维·服务器·数据库
xixingzhe27 小时前
Mysql统计空间增量
数据库·mysql
程序员萌萌8 小时前
Redis的缓存机制和淘汰策略详解
数据库·redis·缓存机制·淘汰策略
不剪发的Tony老师8 小时前
SQLite 3.53.0版本发布,重要更新
数据库·sqlite
Bczheng18 小时前
九.Berkeley DB数据库 序列化和钱包管理(1)
数据库