sql中的左连接和右连接的区别-SQL
SQL 中左连接和右连接的区别
在 SQL 中,连接操作用于将来自不同表的行组合在一起。左连接和右连接是两种类型的连接,它们在处理包含 NULL 值的表的行时表现不同。
左连接
- 定义:将左侧表的每一行与右侧表中匹配的行连接,即使右侧表中没有匹配的行,也会返回左侧表的每一行。
- 结果:左侧表的每一行都包含在结果集中,即使右侧表中没有匹配的行,这些行中的右侧表列将显示为 NULL。
- 语法:
SELECT * FROM left_table LEFT JOIN right_table ON left_table.key = right_table.key;
登录后复制
右连接
- 定义:与左连接类似,但它将右侧表的每一行与左侧表中匹配的行连接,即使左侧表中没有匹配的行,也会返回右侧表的每一行。
- 结果:右侧表的每一行都包含在结果集中,即使左侧表中没有匹配的行,这些行中的左侧表列将显示为 NULL。
- 语法:
SELECT * FROM right_table RIGHT JOIN left_table ON right_table.key = left_table.key;
登录后复制
主要区别
特性 | 左连接 | 右连接 |
---|---|---|
优先连接的表 | 左表 | 右表 |
NULL 值处理 | 左表中的 NULL 值不会影响结果 | 右表中的 NULL 值不会影响结果 |
返回的行 | 左表的每一行 | 右表的每一行 |
用途 | 确保左侧表中的所有行都包含在结果集中 | 确保右侧表中的所有行都包含在结果集中 |
示例
考虑以下两个表:
student_id | name |
---|---|
1 | John |
2 | Mary |
course_id | course_name |
---|---|
101 | Math |
102 | Science |
使用左连接:
SELECT * FROM student LEFT JOIN course ON student.student_id = course.student_id;
登录后复制
结果:
student_id | name | course_id | course_name |
---|---|---|---|
1 | John | 101 | Math |
2 | Mary | NULL | NULL |
使用右连接:
SELECT * FROM course RIGHT JOIN student ON course.student_id = student.student_id;
登录后复制
结果:
course_id | course_name | student_id | name |
---|---|---|---|
101 | Math | 1 | John |
102 | Science | NULL | NULL |