在 mysql 查询语句中,JOIN 扮演的角色很重要,所以掌握其用法很重要。很多同学可能只是会用几种常用的,但要成为高级的工程师是需要掌握透彻,360度全无死角。
图片精华版
data:image/s3,"s3://crabby-images/815b2/815b27bef312cb01330f90463da7db73954fbafc" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
文字解释版
1. 需要准备好两个table:subject(学科表)和 student_score(学生成绩表)
通过学生成绩表的subject_id字段(学科ID)和学科表的id字段(主键ID)进行关联
data:image/s3,"s3://crabby-images/601e6/601e601cd6e0c0febfece5af4b70b4d035d6f060" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
data:image/s3,"s3://crabby-images/b8fe9/b8fe9969e8e61137ac7f47c7c0a517ae12f81a3a" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
2. 分别填充数据
data:image/s3,"s3://crabby-images/26f2c/26f2ccf88a0713f418132585b31f919a1303235a" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
data:image/s3,"s3://crabby-images/3d287/3d287acd21451662193889151c741da60d9a97fa" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
3. inner join
语句:select score.student_name,score.score,subject.name,subject.teacher from student_score as score inner join subject on score.subject_id = subject.id;
data:image/s3,"s3://crabby-images/a9c19/a9c1982fbaa54187f23e526e4dc1c3bad157968d" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
4. left join (共有+右表不匹配补NULL)
语句:select score.student_name,score.score,subject.name,subject.teacher from student_score as score left join subject on score.subject_id = subject.id;
data:image/s3,"s3://crabby-images/1c312/1c31222e5cc04fe31b4020119a9aa1e0482f7348" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
5. left join (左表独有)
语句:select score.student_name,score.score,subject.name,subject.teacher from student_score as score left join subject on score.subject_id = subject.id where subject.id is null;
data:image/s3,"s3://crabby-images/eb94e/eb94eb7f8156aa6748cce500129caafd83edd9e3" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
6. right join (共有+左表不匹配补NULL)
语句:select score.student_name,score.score,subject.name,subject.teacher from student_score as score right join subject on score.subject_id = subject.id;
data:image/s3,"s3://crabby-images/dae8e/dae8e56bad9be2fe67ad238b5ad3b759b03134bd" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
7. right join (右表独有)
语句:select score.student_name,score.score,subject.name,subject.teacher from student_score as score right join subject on score.subject_id = subject.id where score.id is null;
data:image/s3,"s3://crabby-images/f8900/f89007ea6ea05aa5ca8695eb0312269dfb518337" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
8. union (左右表合并并去重)
语句:
select score.student_name,score.score,subject.name,subject.teacher from student_score as score left join subject on score.subject_id = subject.id
union
select score.student_name,score.score,subject.name,subject.teacher from student_score as score right join subject on score.subject_id = subject.id;
data:image/s3,"s3://crabby-images/08515/085156b762eb16ef2796537b295090e6109ce831" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
9. union (左右表独有)
语句:
select score.student_name,score.score,subject.name,subject.teacher from student_score as score left join subject on score.subject_id = subject.id where subject.id is null
union
select score.student_name,score.score,subject.name,subject.teacher from student_score as score right join subject on score.subject_id = subject.id where score.id is null;
data:image/s3,"s3://crabby-images/18799/1879974afda8268ba031f11b6f77d1d95b8abd6d" alt="一张图搞定七种JOIN关系 一张图搞定七种JOIN关系"
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。