MySQL 高级 (二) ---join关联查询

Posted IT路上的小白

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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共有,也就是交集。

   

2.left join

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

   

3.right join

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

   

4.A独有

   

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

5.B独有

   

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

6.AB全有(并集)

   

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

7.A、B独有并集

   

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

总结

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

 

以上是关于MySQL 高级 (二) ---join关联查询的主要内容,如果未能解决你的问题,请参考以下文章

MySQL基本SQL语句之高级操作

MySQL数据库高级——自定义函数

MySQL高级索引和视图

MySQL高级篇

MySQL高级-showProfile

MySQL高级(进阶)SQL语句