zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

MySQL七大JOIN的具体使用

mysql 使用 具体 Join 七大
2023-06-13 09:19:42 时间

img

A的独有+AB的公有 B的独有+AB的公有 AB的公有 A的独有+B的独有+AB的公有 A的独有+B的独有

建表

部门表

DROP TABLE IF EXISTS `dept`;
CREATE TABLE `dept` (
`dept_id` int(11) NOT NULL AUTO_INCREMENT,
`dept_name` varchar(30) DEFAULT NULL,
`dept_number` int(11) DEFAULT NULL,
PRIMARY KEY (`dept_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO `dept` VALUES ( 1 , AA , 100 );
INSERT INTO `dept` VALUES ( 2 , BB , 200 );
INSERT INTO `dept` VALUES ( 3 , CC , 300 );
INSERT INTO `dept` VALUES ( 4 , DD , 400 );
INSERT INTO `dept` VALUES ( 5 , HH , 500 );

员工表

DROP TABLE IF EXISTS `emp`;
CREATE TABLE `emp` (
`emp_id` int(11) NOT NULL AUTO_INCREMENT,
`emp_name` varchar(30) DEFAULT NULL,
`emp_age` int(11) DEFAULT NULL,
`dept_id` int(11) NOT NULL,
PRIMARY KEY (`emp_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO `emp` VALUES( 1 , zhangsan , 20 , 1 );
INSERT INTO `emp` VALUES( 2 , lisi , 25 , 6 );
INSERT INTO `emp` VALUES( 3 , wangwu , 19 , 4 );
INSERT INTO `emp` VALUES( 4 , zhaoliu , 29 , 5 );
INSERT INTO `emp` VALUES( 5 , xiaohong , 30 , 2 );
INSERT INTO `emp` VALUES( 6 , xiaohu , 26 , 3 );
INSERT INTO `emp` VALUES( 7 , zhangle , 23 , 3 );
INSERT INTO `emp` VALUES( 8 , qingtian , 38 , 3 );
INSERT INTO `emp` VALUES( 9 , xiayutian , 36 , 2 );
INSERT INTO `emp` VALUES( 10 , fangjia , 40 , 1 );

情景分析

1.左连接(left join)

A的独有+AB的公有

SELECT * from emp e LEFT JOIN dept d ON e.dept_id=d.dept_id;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6001csXo-1645839606074)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/1.png)]

2.右连接(right join)

B的独有+AB的公有

SELECT * from emp e RIGHT JOIN dept d ON e.dept_id=d.dept_id;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1DOM4wMc-1645839606075)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/8.png)]

3.内连接(inner join)

AB的公有

SELECT * from emp e INNER JOIN dept d ON e.dept_id=d.dept_id;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VcTWd1rp-1645839606075)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/6.png)]

4.左外连接(left join且右表=null)

A的独有

SELECT * from emp e LEFT JOIN dept d ON e.dept_id=d.dept_id WHERE d.dept_id is null;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-C9UqUnL7-1645839606075)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/4-1637892421625.png)]

5. 右外连接(right join且左表=null)

B的独有

SELECT * from emp e RIGHT JOIN dept d ON e.dept_id=d.dept_id WHERE e.dept_id is null;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9r2SK10L-1645839606076)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/5.png)]

6. 全连接(full outer join)

A的独有+B的独有+AB的公有

注意:MySQL不支持FULL OUTER JOIN(在ORACLE支持)。

因此使用UNION的方式来实现,可以**合并+去重**

应用场景:

要查询的结果来自于多个表,且多个表没有直接的连接关系,但查询的信息一致时

特点:

1、要求多条查询语句的查询列数是一致的

2、要求多条查询语句的查询的每一列的类型和顺序最好一致

3、union关键字**默认去重,如果使用union all 可以包含重复项**

SELECT * from emp e LEFT JOIN dept d ON e.dept_id=d.dept_id UNION SELECT * FROM emp e RIGHT JOIN dept d ON e.dept_id=d.dept_id;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5WRgeq2U-1645839606076)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/ICD701IP7L9IC%60N3E2T%5DZSV.png)]

7. 全外连接(full outer join且左右表=null)

A的独有+B的独有

SELECT * from emp e LEFT JOIN dept d ON e.dept_id=d.dept_id WHERE d.dept_id is null UNION SELECT * FROM emp e RIGHT JOIN dept d ON e.dept_id=d.dept_id WHERE e.dept_id is null;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pnfuDyeQ-1645839606077)(C:/Users/%E9%BB%84%E5%87%AF%E5%AE%87/Desktop/%E6%98%A5%E6%8B%9B/MySQL/MySQL.assets/7.png)]


我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题

本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 MySQL七大JOIN的具体使用