SQL左右连接详解

在SQL中,"左右链接"通常指的是LEFT JOIN(左连接)和RIGHT JOIN(右连接)。这里用一个简单的方式解释这两种连接方式。

LEFT JOIN (左连接)

想象一下,你有一个班级的学生名单,这是你的"左表"。然后你有另一个表,记录了哪些学生交了作业,这是你的"右表"。现在,你想知道每个学生是否交了作业。

  • LEFT JOIN 就像是你在检查学生的作业情况时,会从你的学生名单开始。对于名单上的每一个学生,你会查找他们是否在交作业的记录中出现过。如果找到了,就把这两个信息连在一起;如果没有找到,那么对于那些没有交作业记录的学生,就会显示为NULL。

简单来说,LEFT JOIN会保留所有左表中的记录,并且只保留右表中匹配的记录。如果不匹配,则显示为NULL。

RIGHT JOIN (右连接)

还是用上面的例子,但是这次你想从作业记录表开始,这个表是你现在关注的"右表"。

  • RIGHT JOIN 就是你会检查每一份交上来的作业,并且查看是哪个学生交的。对于每一份作业,你都会去找这个学生的名字出现在你的学生名单上。如果找到了,就把两个信息连起来;如果没有找到,那么就会出现NULL。

换句话说,RIGHT JOIN会保留所有右表中的记录,并且只保留左表中匹配的记录。如果不匹配,则显示为NULL。

总结

  • LEFT JOIN: 以左表为主,保留左表的所有行,对于右表未匹配到的行,用NULL填充。
  • RIGHT JOIN: 以右表为主,保留右表的所有行,对于左表未匹配到的行,用NULL填充。

如果你想要的是两边都包含的数据,可以考虑使用INNER JOIN来只获取两个表中都有数据的部分,或者使用FULL OUTER JOIN来获取两个表中所有的数据,不论是匹配与否。不过需要注意的是,FULL OUTER JOIN并不是所有数据库系统都支持的。

假设我们有两个表:一个是Students表,一个是Grades表。Students表包含了学生的信息,而Grades表包含了学生的成绩记录。

表结构示例
复制代码
CREATE TABLE Students (
    StudentID int,
    Name varchar(255),
    Age int
);

CREATE TABLE Grades (
    StudentID int,
    Subject varchar(255),
    Grade int
);
插入数据
复制代码
INSERT INTO Students (StudentID, Name, Age)
VALUES (1, 'Alice', 15),
       (2, 'Bob', 16),
       (3, 'Charlie', 17),
       (4, 'David', 18);

INSERT INTO Grades (StudentID, Subject, Grade)
VALUES (1, 'Math', 90),
       (2, 'Science', 85),
       (2, 'History', 80),
       (3, 'English', 75),
       (4, 'Physics', 88);
LEFT JOIN 示例

如果我们想找出所有学生以及他们的成绩记录,我们可以使用LEFT JOIN:

复制代码
SELECT Students.Name, Grades.Subject, Grades.Grade
FROM Students
LEFT JOIN Grades ON Students.StudentID = Grades.StudentID;

这条语句将返回所有学生的姓名,以及他们在不同科目中的成绩。如果有学生没有成绩记录,那么对应的Subject和Grade字段将会是NULL。

输出结果可能如下:

复制代码
Name   | Subject | Grade
-----------------------------
Alice  | Math    | 90
Bob    | Science | 85
Bob    | History | 80
Charlie| English | 75
David  | Physics | 88

注意:由于Bob有两门课的成绩,所以Bob的名字会出现在输出结果中两次。

RIGHT JOIN 示例

如果我们对成绩表更感兴趣,想找出所有科目的成绩记录以及对应的学生名字,我们可以使用RIGHT JOIN:

复制代码
SELECT Students.Name, Grades.Subject, Grades.Grade
FROM Students
RIGHT JOIN Grades ON Students.StudentID = Grades.StudentID;

这条语句将返回所有成绩记录及其对应的学生名字。如果某个成绩记录对应的学生不存在于Students表中,那么Name字段将会是NULL。

假设我们删除了一个学生记录,但该学生的成绩记录还存在于Grades表中,那么使用RIGHT JOIN将会显示出这名学生的信息为NULL。

相关推荐
27669582927 分钟前
拼多多 anti-token unidbg 分析
java·python·go·拼多多·pdd·pxx·anti-token
YGGP20 分钟前
MySQL 的事务
数据库·mysql
喻师傅28 分钟前
横扫SQL面试——时间序列分组与合并(会话划分)问题
大数据·sql·面试
xyliiiiiL38 分钟前
二分算法到红蓝染色
java·数据结构·算法
编程、小哥哥42 分钟前
spring之添加freemarker模版熏染
java·后端·spring
hong_zc1 小时前
Spring 拦截器与统一功能的处理
java·后端·spring
User_芊芊君子1 小时前
【Java】——数组深度解析(从内存原理到高效应用实践)
java·开发语言
珹洺2 小时前
C++从入门到实战(十)类和对象(最终部分)static成员,内部类,匿名对象与对象拷贝时的编译器优化详解
java·数据结构·c++·redis·后端·算法·链表
一 乐2 小时前
网红酒店|基于java+vue的网红酒店预定系统(源码+数据库+文档)
java·开发语言·数据库·毕业设计·论文·springboot·网红酒店预定系统
Alfadi联盟 萧瑶3 小时前
Python-用户账户与应用程序样式
数据库·sqlite