【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
•
数据库
文章目录
- 连接
-
- 七种JOIN介绍
- 练习
-
- 建表+存储数据
- 笛卡尔积
- 内连接
- 左连接
- 右连接
- A表独有
- B表独有
- 全连接
-
- 实现方式一:左连接+右连接+公共部分去重
- 实现方式二:左连接+B独有
- A独有+B独有
- 文章说明
连接
七种JOIN介绍
| 图形 | 连接方式 | 说明 | SQL |
|---|---|---|---|
![]() |
内连接 | 共有部分 | SELECT |
![]() |
左连接 | A表独有+共有部分 | SELECT |
![]() |
右连接 | B表独有+共有部分 | SELECT |
![]() |
A的独有 | SELECT |
|
![]() |
B的独有 | SELECT |
|
![]() |
全连接 | A的独有+共有部分+B的独有 | SELECT |
![]() |
A独有+B独有 | SELECT |
练习
建表+存储数据
CREATE TABLE `tbl_emp` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) DEFAULT NULL,
`deptId` int(11) DEFAULT NULL,
PRIMARY KEY (`id`) ,
KEY `fk_dept_id`(`deptId`)
)ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8;
CREATE TABLE `tbl_dept` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`deptName` varchar(30) DEFAULT NULL,
`locAdd` varchar(40) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8;
insert into tbl_dept(deptName,locAdd) values('RD',11);
insert into tbl_dept(deptName,locAdd) values('HR',12);
insert into tbl_dept(deptName,locAdd) values('MK',13);
insert into tbl_dept(deptName,locAdd) values('MIS',14);
insert into tbl_dept(deptName,locAdd) values('FD',15);
insert into tbl_emp(NAME,deptId) values('z3',1);
insert into tbl_emp(NAME,deptId) values('z4',1);
insert into tbl_emp(NAME,deptId) values('z5',1);
insert into tbl_emp(NAME,deptId) values('w5',2);
insert into tbl_emp(NAME,deptId) values('w6',2);
insert into tbl_emp(NAME,deptId) values('s7',3);
insert into tbl_emp(NAME,deptId) values('s8',4);
insert into tbl_emp(NAME,deptId) values('s9',51);
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qUHuXxvA-1686824977740)(assets/1686824851787-7.png)]](/img/d8/e3b74fcfc10a4558ab766a20439624db.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8stgnQnE-1686824977740)(assets/1686824851788-8.png)]](/img/68/b71faa63928841d5bbbb06516f72b48a.png)
笛卡尔积
select * from tbl_emp,tbl_dept;
5条数据和8条数据两两组合,一共40条,结果如下
"id" "name" "deptId" "id" "deptName" "locAdd" "1" "z3" "1" "5" "FD" "15" "1" "z3" "1" "4" "MIS" "14" "1" "z3" "1" "3" "MK" "13" "1" "z3" "1" "2" "HR" "12" "1" "z3" "1" "1" "RD" "11" "2" "z4" "1" "5" "FD" "15" "2" "z4" "1" "4" "MIS" "14" "2" "z4" "1" "3" "MK" "13" "2" "z4" "1" "2" "HR" "12" "2" "z4" "1" "1" "RD" "11" "3" "z5" "1" "5" "FD" "15" "3" "z5" "1" "4" "MIS" "14" "3" "z5" "1" "3" "MK" "13" "3" "z5" "1" "2" "HR" "12" "3" "z5" "1" "1" "RD" "11" "4" "w5" "2" "5" "FD" "15" "4" "w5" "2" "4" "MIS" "14" "4" "w5" "2" "3" "MK" "13" "4" "w5" "2" "2" "HR" "12" "4" "w5" "2" "1" "RD" "11" "5" "w6" "2" "5" "FD" "15" "5" "w6" "2" "4" "MIS" "14" "5" "w6" "2" "3" "MK" "13" "5" "w6" "2" "2" "HR" "12" "5" "w6" "2" "1" "RD" "11" "6" "s7" "3" "5" "FD" "15" "6" "s7" "3" "4" "MIS" "14" "6" "s7" "3" "3" "MK" "13" "6" "s7" "3" "2" "HR" "12" "6" "s7" "3" "1" "RD" "11" "7" "s8" "4" "5" "FD" "15" "7" "s8" "4" "4" "MIS" "14" "7" "s8" "4" "3" "MK" "13" "7" "s8" "4" "2" "HR" "12" "7" "s8" "4" "1" "RD" "11" "8" "s9" "51" "5" "FD" "15" "8" "s9" "51" "4" "MIS" "14" "8" "s9" "51" "3" "MK" "13" "8" "s9" "51" "2" "HR" "12" "8" "s9" "51" "1" "RD" "11"
内连接
SELECT * FROM tbl_emp a INNER JOIN tbl_dept b ON a.deptId = b.id;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aZ35ILZ2-1686824977740)(assets/1686824851788-9.png)]](/img/0b/47f08a98082548e18a3a7ad8585fa773.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sNac9oI7-1686824977741)(assets/1686824851788-10.png)]](/img/4a/4f5fecb7e5fb420fafc75444054e371c.png)
左连接
SELECT * FROM tbl_emp a LEFT JOIN tbl_dept b ON a.deptId = b.id;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-veaxxZmd-1686824977741)(assets/1686824851788-11.png)]](/img/d8/018512096d43498680d87e1cb01a4355.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WbjW4vGV-1686824977741)(assets/1686824851788-12.png)]](/img/52/738550f5d3ca4a0e86207cd15ace9519.png)
右连接
SELECT * FROM tbl_emp a RIGHT JOIN tbl_dept b ON a.deptId = b.id;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u96RObbU-1686824977741)(assets/1686824851788-13.png)]](/img/89/6c6454d081a64b8684a8f8c632a9a293.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Q9huZfmw-1686824977741)(assets/1686824851788-14.png)]](/img/49/fbdb4c19d3e449a78477dcba79596de9.png)
A表独有
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hR7svfpX-1686824977742)(assets/1686824851788-15.png)]](/img/76/91b6e144a5e84193b0fd48204fc32477.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BrFmCxzC-1686824977742)(assets/1686824851788-16.png)]](/img/97/6b94f0ec99874b0fab372917b25f64f7.png)
SELECT * FROM tbl_emp a LEFT JOIN tbl_dept b ON a.deptId = b.id WHERE b.id is null;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2KKU8i1R-1686824977742)(assets/1686824851789-17.png)]](/img/01/7ff8a13c3faf4ac987f00a96ff8fdef1.png)
B表独有
SELECT * FROM tbl_emp a RIGHT JOIN tbl_dept b ON a.deptId = b.id WHERE a.deptId is null;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1FUBJoXE-1686824977742)(assets/1686824851789-18.png)]](/img/ab/92b55680e07c404791fb9d9ed89b5484.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-29w3Q3Vf-1686824977742)(assets/1686824851789-19.png)]](/img/6f/abc9c8ac60df4f3db0d7329993166f66.png)
全连接
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UrTh9p5N-1686824977743)(assets/1686824851789-20.png)]](/img/74/ae0bb32f749b42db8d3b2db5ea12344c.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jtIDkl7R-1686824977743)(assets/1686824851789-21.png)]](/img/25/a68e37a491fd4b0b91437814c681f5cd.png)
尝试换一种方式实现:A的独有+共有+B的独有
实现方式一:左连接+右连接+公共部分去重
SELECT * FROM tbl_emp a LEFT JOIN tbl_dept b ON a.deptId = b.id UNION SELECT * FROM tbl_emp a RIGHT JOIN tbl_dept b ON a.deptId = b.id;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LkhQ6tcO-1686824977743)(assets/1686824851789-22.png)]](/img/04/75d6b41e89294b908145b3dfc2fd4d47.png)
实现方式二:左连接+B独有
SELECT * FROM tbl_emp a LEFT JOIN tbl_dept b ON a.deptId = b.id UNION SELECT * FROM tbl_emp a RIGHT JOIN tbl_dept b ON a.deptId = b.id WHERE a.deptId is null;
A独有+B独有
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KdkdloFq-1686824977744)(assets/1686824851789-23.png)]](/img/b2/16d27dfee51d48ecb58cabc994263a67.png)
SELECT * FROM tbl_emp a LEFT JOIN tbl_dept b ON a.deptId = b.id WHERE b.id is null UNION SELECT * FROM tbl_emp a RIGHT JOIN tbl_dept b ON a.deptId = b.id WHERE a.deptId is null;
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9dcf7yHP-1686824977744)(assets/1686824851789-24.png)]](/img/bf/de9ce5e872d242ee92b9c80be1168acd.png)
文章说明
本文章为本人学习尚硅谷的学习笔记,文章中大部分内容来源于尚硅谷视频(点击学习尚硅谷相关课程),也有部分内容来自于自己的思考,发布文章是想帮助其他学习的人更方便地整理自己的笔记或者直接通过文章学习相关知识,如有侵权请联系删除,最后对尚硅谷的优质课程表示感谢。
本文来自网络,不代表协通编程立场,如若转载,请注明出处:https://net2asp.com/6bd3238b75.html


![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mQHmQOL5-1686824977738)(assets/1686824851787-1.png)]](/img/71/9c90dfa5d8f84f1bb98a728268f78dab.png)

![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hVV4XXtO-1686824977738)(assets/1686824851787-3.png)]](/img/7c/20d9bea9c9394b1fad8f74e204e904b0.png)

![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T5XPhb8d-1686824977739)(assets/1686824851787-5.png)]](/img/ba/d97e9f7c3df1437ba3bf206398c0cf8f.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-w50kiG6r-1686824977739)(assets/1686824851787-6.png)]](/img/17/c1b9b6d2aba9413ca0ff4a36ec099703.png)