mysql高级的join_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共有,也就是交集。

99c796fd882a6b685807a1eef0ed9c44.png

6f5a858901347f6e13117a798c1dd196.png

2.left join

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

cbd7f657fafd2e85800070105b440e37.png

e8eebb49df9d846189d7c312dcee2275.png

3.right join

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

e7a721c12551cf80ed4a8163573c3fc1.png

5d3bf592625949a621358a06119b69fd.png

4.A独有

a036d68e3d38e99d0b091d7f9b202b30.png

c1e9e7c477db59140844d9a7b9b72bb4.png

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

5.B独有

46c017fabf234b65016fb1bd544899ec.png

aea1d4b2a683f2bb7693e7475883d1cc.png

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

6.AB全有(并集)

366a2e013d3e7907888922653db2027c.png

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

845dc625046720218720e885db3ae46e.png

7.A、B独有并集

2b23c6112e907908cd5ca20cb0ac4bf9.png

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

b9e86900d6cf5563cd9698062d060ce6.png

总结

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

by Shawn Chen,2018.6.21日,上午。

相关内容

318ea5a4889e17152039a224ce0ac63c.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值