专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

MySQL高级知识(二)——Join查询

前言:该篇主要对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共有,也就是交集。

77_1.png

77_2.png

2.left join

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

77_3.png

77_4.png

3.right join

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

77_5.png

77_6.png

4.A独有

77_7.png

77_8.png

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

5.B独有

77_9.png

77_10.png

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

6.AB全有(并集)

77_11.png

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

77_12.png

7.A、B独有并集

77_13.png

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

77_14.png

总结

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


by Shawn Chen,2018.6.21日,上午。


相关内容

MySQL高级知识系列目录

https://www.cnblogs.com/developer_chan/category/1020652.html

文章永久链接:https://tech.souyunku.com/13726

未经允许不得转载:搜云库技术团队 » MySQL高级知识(二)——Join查询

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们