2021-06-05 11:05  阅读(3018)
文章分类:MySQL 高级知识 文章标签:MySQLMySQL 技术内幕MySQL 高级
©  原文作者:developer_chan 原文地址:https://www.cnblogs.com/developer_chan

前言:该篇主要对MySQL中join语句的七种情况进行总结。


0.准备

join主要根据两表或多表之间列的关系,从这些表中进行数据的查询。

首先创建两张表:tb_emp(员工表)和tb_dept(部门表),并插入相关测试数据。

1.tb_emp表。

        DROP TABLE IF EXISTS `tb_emp`;
        CREATE TABLE `tb_emp` (
          `id` int(11) NOT NULL AUTO_INCREMENT,
          `name` varchar(20) NOT NULL,
          `deptid` int(11) NOT NULL,
          PRIMARY KEY (`id`),
          KEY `idx_tb_emp_name` (`name`)
        ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
        INSERT INTO `tb_emp`(name,deptid) VALUES ('jack', '1');
        INSERT INTO `tb_emp`(name,deptid) VALUES ('tom', '1');
        INSERT INTO `tb_emp`(name,deptid) VALUES ('tonny', '1');
        INSERT INTO `tb_emp`(name,deptid) VALUES ('mary', '2');
        INSERT INTO `tb_emp`(name,deptid) VALUES ('rose', '2');
        INSERT INTO `tb_emp`(name,deptid) VALUES ('luffy', '3');
        INSERT INTO `tb_emp`(name,deptid) VALUES ('outman', '14');

2.tb_dept表。

        DROP TABLE IF EXISTS `tb_dept`;
        CREATE TABLE `tb_dept` (
          `id` int(11) NOT NULL AUTO_INCREMENT,
          `deptname` varchar(20) NOT NULL,
          PRIMARY KEY (`id`)
        ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
        INSERT INTO `tb_dept`(deptname) VALUES ('研发');
        INSERT INTO `tb_dept`(deptname) VALUES ('测试');
        INSERT INTO `tb_dept`(deptname) VALUES ('运维');
        INSERT INTO `tb_dept`(deptname) VALUES ('经理');

从上表插入的数据可知outman是没有对应部门的。

1.inner join

注:A表示左表,B表示右表,下同。

inner join:A、B共有,也就是交集。

202106051105254691.png

202106051105258672.png

2.left join

left jion:A独有+AB共有(交集)

202106051105262393.png

202106051105266734.png

3.right join

right join:B独有+AB共有(交集)

202106051105270035.png

202106051105273586.png

4.A独有

202106051105276687.png

202106051105280178.png

注:参照left join,A独有只是将AB交集部分去掉。

5.B独有

202106051105282749.png

2021060511052857610.png

注:参照right join,B独有只是将AB交集部分去掉。

6.AB全有(并集)

2021060511052882811.png

由于mysql中不支持full outer join,所以这里通过union进行转换。AB并集:AB交集+A独有+B独有。

2021060511052917912.png

7.A、B独有并集

2021060511052954913.png

A、B独有并集,相当于A、B全有去掉AB的共有(交集)。

2021060511052993314.png

总结

这里主要对MySQL中join语句的7中用法进行了总结,主要注意MySQL不支持full outer join,所以需要对其进行转换变形,最终达到效果。

点赞(2)
版权归原创作者所有,任何形式转载请联系作者; Java 技术驿站 >> MySQL高级知识(二)——Join查询
上一篇
MySQL高级知识(一)——基础
下一篇
MySQL高级知识(三)——索引