SQL:MySQL7种JOIN用法总结

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: SQL:MySQL7种JOIN用法总结

d6.1.jpeg

数据准备

1、建2张表

# 姓名表
create table table_name(
  id int(11) primary key auto_increment,
  user_id int(11) default 0,
  name varchar(5) default ''
);
# 年龄表
create table table_age(
  id int(11) primary key auto_increment,
  user_id int(11) default 0,
  age int(11) default 0
);

2、原始数据

# user_id, name, age
(1, "小赵", 21), 
(2, "小钱", 22), 
(3, "小孙", 23), 

将6条数据分为两部分插入到数据库中

# 名字表少一条 user_id = 3
insert into table_name(user_id, name)
values(1, "小赵"), (2, "小钱");
# 年龄表少一条 user_id = 2
insert into table_age(user_id, age)
values(1, 21), (3, 23);

3、查看数据

mysql> select * from table_name;
+----+---------+--------+
| id | user_id | name   |
+----+---------+--------+
|  1 |       1 | 小赵   |
|  2 |       2 | 小钱   |
+----+---------+--------+
mysql> select * from table_age;
+----+---------+------+
| id | user_id | age  |
+----+---------+------+
|  1 |       1 | 21   |
|  3 |       3 | 23   |
+----+---------+------+

d6.2.png


mysql> select a.user_id, name, age  
    -> from table_name as a inner join table_age as b  
    -> on a.user_id=b.user_id;
+---------+--------+------+
| user_id | name   | age  |
+---------+--------+------+
|       1 | 小赵   |   21 |
+---------+--------+------+

2、LEFT JOIN (左连接)

d6.3.png


mysql> select a.user_id, name, age
from table_name as a left join table_age as b
on a.user_id=b.user_id;
+---------+--------+------+
| user_id | name   | age  |
+---------+--------+------+
|       1 | 小赵   |   21 |
|       2 | 小钱   | NULL |
+---------+--------+------+

3、RIGHT JOIN(右连接)

d6.4.png

mysql> select b.user_id, name, age
from table_name as a right join table_age as b
on a.user_id=b.user_id;
+---------+--------+------+
| user_id | name   | age  |
+---------+--------+------+
|       1 | 小赵   |   21 |
|       3 | NULL   |   23 |
+---------+--------+------+

4、UNION(全连接)

d6.5.png


mysql> select a.user_id, name, age 
from table_name as a left join table_age as b
on a.user_id =b.user_id
union
select b.user_id, name, age 
from table_name as a right join table_age as b
on a.user_id =b.user_id;
+---------+--------+------+
| user_id | name   | age  |
+---------+--------+------+
|       1 | 小赵   |   21 |
|       2 | 小钱   | NULL |
|       3 | NULL   |   23 |
+---------+--------+------+

5、LEFT JOIN EXCLUDING INNER JOIN(左连接-内连接)

d6.6.png


mysql> select a.user_id, name, age
    -> from table_name as a left join table_age as b
    -> on a.user_id=b.user_id
    -> where b.user_id is null;
+---------+--------+------+
| user_id | name   | age  |
+---------+--------+------+
|       2 | 小钱   | NULL |
+---------+--------+------+

6.RIGHT JOIN EXCLUDING INNER JOIN(右连接-内连接)

d6.7.png


mysql> select b.user_id, name, age
    -> from table_name as a right join table_age as b
    -> on a.user_id=b.user_id
    -> where a.user_id is null;
+---------+------+------+
| user_id | name | age  |
+---------+------+------+
|       3 | NULL |   23 |
+---------+------+------+

7、OUTER JOIN EXCLUDING INNER JOIN(外连接-内连接)

d6.8.png


mysql> select a.user_id, name, age
    -> from table_name as a left join table_age as b
    -> on a.user_id =b.user_id
    -> where b.user_id is null
    -> union
    -> select b.user_id, name, age
    -> from table_name as a right join table_age as b
    -> on a.user_id =b.user_id
    -> where a.user_id is null;
+---------+--------+------+
| user_id | name   | age  |
+---------+--------+------+
|       2 | 小钱   | NULL |
|       3 | NULL   |   23 |
+---------+--------+------+

8、笛卡尔积

mysql> select * from table_name join table_age;
+----+---------+--------+----+---------+------+
| id | user_id | name   | id | user_id | age  |
+----+---------+--------+----+---------+------+
|  1 |       1 | 小赵   |  1 |       1 |   21 |
|  2 |       2 | 小钱   |  1 |       1 |   21 |
|  1 |       1 | 小赵   |  2 |       3 |   23 |
|  2 |       2 | 小钱   |  2 |       3 |   23 |
+----+---------+--------+----+---------+------+

总结

操作

关键字

解释

图示

内连接

INNER JOIN

A ∩ B A \cap BA∩B

 

左连接

LEFT JOIN

a ∈ A a \in Aa∈A

 

右连接

RIGHT JOIN

a ∈ B a \in Ba∈B

 

全连接

UNION

A ∪ B A \cup BA∪B

 

左表独有

LEFT JOIN WHERE

A − A ∩ B A - A \cap BA−A∩B

 

右表独有

RIGHT JOIN WHERE

B − A ∩ B B - A \cap BB−A∩B

 

并集去交集

UNION WHERE

A ∪ B − A ∩ B A \cup B - A \cap BA∪B−A∩B


参考

1、一张图看懂 SQL 的各种 join 用法

2、mysql中的几种join 及 full join问题

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
18天前
|
SQL 关系型数据库 MySQL
快速学习MySQL SQL语句
快速学习MySQL SQL语句
|
3月前
|
SQL 关系型数据库 MySQL
Mysql SQL的一些特殊用法记录
1、查询group by having 中having不起作用,及解决
15 0
|
5月前
|
SQL 关系型数据库 MySQL
|
12月前
|
SQL 前端开发 算法
【MySQL学习笔记】系列四:基本的SELECT语句(一)
【MySQL学习笔记】系列四:基本的SELECT语句(一)
|
12月前
|
SQL 存储 关系型数据库
【MySQL学习笔记】系列四:基本的SELECT语句(二)
【MySQL学习笔记】系列四:基本的SELECT语句(二)
|
12月前
|
SQL Oracle 关系型数据库
【MySQL】SQL常用函数总结
工资等级表创建语句如下:
|
SQL 存储 安全
【MySQL】SQL常用基础语句总结
在学习MySQL前,我们先来认识一下SQL语句.它分为以下几种:DDL 数据操作语言,用来定义数据库对象(数据库,表,字段),DML数据操作语言,用来对数据库表进行增删改,DQL数据查询语言,用来查询数据库表的记录,DCL数据控制语言,用来创建数据库用户,控制数据库的访问权限,学习数据库中最主要的部分就是学习 MySQL 的增删改查(CRUD)。
|
SQL 关系型数据库 MySQL
MySQL实战,SQL语句
MySQL实战,SQL语句
135 0
|
SQL 关系型数据库 MySQL
SQL:MySQL7种JOIN用法总结
SQL:MySQL7种JOIN用法总结
220 0
SQL:MySQL7种JOIN用法总结
|
SQL 算法 前端开发
8种MySQL常见SQL错误用法详解
8种MySQL常见SQL错误用法详解
377 0