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

摘要:
前言:本文主要总结了MySQL中join语句的七种情况。0。根据两个或多个表的列之间的关系,准备联接以从这些表中查询数据。首先,创建两个表:tb_ Emp和tb_ Dept(部门表)并插入相关的测试数据。1.tb_ Emp表。可拆卸的附件`tb_ emp`;可创建`tb_emp`(`id`int(11)NOTNULLAUT_INCREMENT`

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

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

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

2.left join

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

   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,所以需要对其进行转换变形,最终达到效果。


by Shawn Chen,2018.6.21日,上午。 


相关内容

MySQL高级知识系列目录

免责声明:文章转载自《MySQL高级知识(二)——Join查询》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Pandas数据合并方法merge()、concat()、combine_first()方法,数据的重塑和矩阵转置等操作的实现php中_initialize()函数与 __construct()函数的区别说明下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

MySQL数据库接口的VC实现与应用

摘要:MySQL数据库作为一种网络数据库性能十分出色,但其在应用软件中使用较少。本文将主要探讨MySQL提供的两种数据库接口 ——(ODBC API和C API)在VC中的应用,并且形成一个类用以封装C API数据库接口的功能。 关键词:MySQL;数据库接口;ODBC API;C API下载本文配套源代码 引言 随着现代计算机软硬件及网络技术的发展,在...

Linux中使用mysqldump对MySQL数据库进行定时备份

#!/bin/bash PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin export PATH export LANG=en_US.UTF-8 savedir=/log/database_ba...

Mysql储存过程5: while

循环结构 while create procedure name() begin while 条件 do SQL语句 end while; end$ create procedure aa6() begin declare number int default 0; while num...

mysql如何修改所有的definer

mysql中的definer是什么,有什么作用? 我们在mysql创建view、trigger、function、procedure、event时都会定义一个Definer=‘xxx’,类似如下: CREATE ALGORITHM =UNDEFINED DEFINER = `root`@`%` SQL SECURITY DEFI...

YY 数据库平台化建设实践

钟建辉,YY基础运维经理,负责数据库及服务器基础运维工作,在数据库领域有超过10年的工作经验,见证了YY数据库平台化从”0”到”1”的整个历程,目前主要致力于推动YY数据库、服务器平台化建设。 以下为钟建辉老师演讲实录: 我的侧重点主要在运维DBA的角度介绍我们数据库系统。前面周老师就是研发的角度怎么看我们数据库平台系统。 一、YY数据库团队面临问...

Linux Mysql 安装 开启远程连接 供python agent 连接测试 Mark

Linux     6.3     (1) cat  /etc/redhat-release uname -a 查看yum 源:   阿里源 无源运行: echo 下载阿里云的yum源配置 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6...