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共有,也就是交集。

满足某一条件的A,B内部的数据;正因为得到的是内部共有数据,所以连接方式称为内连接。

   mysql join查询_第1张图片

mysql join查询_第2张图片

2.left join

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

这种场景下得到的是A的所有数据,和满足某一条件的B的数据。

   mysql join查询_第3张图片

mysql join查询_第4张图片

3.right join

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

   mysql join查询_第5张图片

mysql join查询_第6张图片

4.A独有

   mysql join查询_第7张图片

mysql join查询_第8张图片

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

5.B独有

   mysql join查询_第9张图片

mysql join查询_第10张图片

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

6.AB全有(并集)

   mysql join查询_第11张图片

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

mysql join查询_第12张图片

7.A、B独有并集

   mysql join查询_第13张图片

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

mysql join查询_第14张图片

总结

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

你可能感兴趣的:(mysql)