原英文文章链接:https://www.codeproject.com/Articles/33052/Visual-Representation-of-SQL-Joins
准备
表A:

-- auto-generated definition
CREATE TABLE table_a
(PK    INT(10)     NOT NULLPRIMARY KEY,Value VARCHAR(25) NULL
)COMMENT '表A';

表B:

-- auto-generated definition
CREATE TABLE table_b
(PK    INT(10)     NOT NULLPRIMARY KEY,Value VARCHAR(50) NULL
)COMMENT '表B';

表A数据:

表B数据:

下面是各种连接的韦恩图:

详细分析
1.INNER JOIN (内连接)
内连接是一种一一映射关系,就是两张表都有的才能显示出来
用韦恩图表示是两个集合的交集,如图:

实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
INNER JOIN table_b B
ON A.PK = B.PK;

查询结果:

2.LEFT JOIN (左连接)
左连接是左边表的所有数据都有显示出来,右边的表数据只显示共同有的那部分,没有对应的部分只能补空显示,所谓的左边表其实就是指放在left join的左边的表
用韦恩图表示如下:

实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
LEFT JOIN  table_b B
ON A.PK = B.PK;

查询结果:

3.RIGHT JOIN(右连接)
右连接正好是和左连接相反的,这里的右边也是相对right join来说的,在这个右边的表就是右表
用韦恩图表示如下:

实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
RIGHT JOIN   table_b B
ON A.PK = B.PK;

查询结果:

4.OUTER JOIN(外连接、全连接)
查询出左表和右表所有数据,但是去除两表的重复数据
韦恩图表示如下:

实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
FULL  JOIN table_b B
ON A.PK = B.PK;

上面代码在mysql执行是报错的,因为mysql不支持全连接,只能用以下代码实现效果,含义是左连接+右连接+去重=全连接:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
LEFT JOIN  table_b B
ON A.PK = B.PKUNION
SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
RIGHT JOIN  table_b B
ON A.PK = B.PK;

查询结果:

5.LEFT JOIN EXCLUDING INNER JOIN(左连接不包含内连接)
这个查询是只查询左边表有的数据,共同有的也不查出来
韦恩图表示如下:

实现代码:

SELECT A.PK AS A_PK, A.Value AS A_Value,
B.Value AS B_Value, B.PK AS B_PK
FROM Table_A A
LEFT JOIN Table_B B
ON A.PK = B.PK
WHERE B.PK IS NULL

查询结果:

6.RIGHT JOIN EXCLUDING INNER JOIN(右连接不包含内连接)
这个查询是只查询右边表有的数据,共同有的也不查出来
韦恩图表示如下:

实现代码:

SELECT A.PK AS A_PK, A.Value AS A_Value, B.PK AS B_PK,
B.Value AS B_Value
FROM Table_A A
RIGHT JOIN Table_B B
ON A.PK = B.PK
WHERE A.PK IS NULL

查询结果:

7.OUTER JOIN EXCLUDING INNER JOIN(外连接不包含内连接)
意思就是查询左右表各自拥有的那部分数据
韦恩图表示如下:

实现代码:

SELECT A.PK AS A_PK, A.Value AS A_Value,
B.Value AS B_Value, B.PK AS B_PK
FROM Table_A A
FULL OUTER JOIN Table_B B
ON A.PK = B.PK
WHERE A.PK IS NULL
OR B.PK IS NULL

由于mysql不支持full join,只能通过下面代码模拟实现:

SELECT  A.PK AS A_PK, A.Value AS A_Value, B.PK AS B_PK,
B.Value AS B_ValueFROM table_a ALEFT JOIN table_b B
ON A.PK = B.PKWHERE B.PK IS NULL
UNION ALLSELECT *FROM table_a ARIGHT JOIN table_b BON A.PK = B.PKWHERE A.PK IS NULL;

查询结果:

数据库左连接、右连接、内连接、全连接笔记相关推荐

  1. mysql表全连接_关于mysql 实现表连接(左,右,内,全连接)

    mysql 实现表连接(左,右,内,全连接) 查询中出现两个表的连接,下面通过实例来讲解一下各种连接查询的不同之处 表 a,和表b 如下图 a 表中 有 abcd b表中有 abcf 内连接:SELE ...

  2. 【Mysql】图解左、右、内与全连接

    一.前言 使用学生表与成绩表来演示Mysql中的各种连接查找 学生表的建表语句如下: CREATE TABLE student(id int(11) NOT NULL AUTO_INCREMENT C ...

  3. 左、右、内、自然连接

    我们先给两张表: tb_dept tb_emp /* 自然连接, 依靠相同的属性列连接,没有相同则不连接 */select * from tb_emp as t1 natural join tb_de ...

  4. 内连接,外连接(左外,右外),全连接(交集),交叉连接(笛卡尔积)

    内连接,外连接(左外,右外),全连接(交集),交叉连接(笛卡尔积) 先略两个表 首先左连接:SELECT * FROM test1 a LEFT JOIN test2 b ON a.id = b.id ...

  5. SQL中的连接(左、右、内连接)

    目录 左连接(LEFT JOIN或LEFT OUTER JOIN): 右连接(RIGHT JOIN或RIGHT OUTER JOIN): 内连接(INNER JOIN也叫等值连接): 全连接(FULL ...

  6. mysql 全表连接_MySQL学习—多表查询(内连接,外链接,全连接)

    一个项目中肯定会有多张数据表,而数据表之间会存在各种各样的关系.这时我们需要的数据,可能不会直接通过一张表全部获取到,这时就需要同时查询多张数据表,得到最后想要的数据. 下面以具体的实例来进行相关知识 ...

  7. 全连接层 时间复杂度_神经网络全连接层(3)

    CNN网络基础结构 神经网络-全连接层(3) 上一回我们聊完了算法,这回我们正式开始写代码.上回在做公式推导的时候,我们实际上只是针对一个数据样本进行推导,而实际中,计算和训练都是一批一批完成的.大多 ...

  8. linux查看全连接队列大小,[TimLinux] TCP全连接队列满

    0. TCP三次握手 syns queue: 半连接队列 accept queue: 全连接队列 控制参数存放在文件:/proc/sys/net/ipv4/tcp_abort_on_overflow中 ...

  9. 神经网络的全连接层_深度神经网络全连接层

    一.概念 全连接层一般在网络的最后部分做分类输出,全连接层的有m个输入和n个输出,每一个输出都和所有的输入相连,相连的权重w都是不一样的,同时每一个输出还有一个bias. 二.前向全连接 假设输入是4 ...

  10. 全连接层的作用_全连接层实现

    本文以<Tensorflow2.0深度学习算法实战教材>参考,代码部分全程手打. 图1 将图1 堆叠可以得到含有多个隐藏层的全连接层,如图2所示.因为当前层的输入要与前一层的输出相匹配:所 ...

最新文章

  1. java mysql 是否插入 成功_您如何确定使用Java和MySQL插入或更新是否成功?
  2. [luoguP1168]中位数(主席树+离散化)
  3. 学python买什么书好-学python3什么书好
  4. python3创建定时任务
  5. Codeforces Round #193 (Div. 2)
  6. GCC跟NASM联合编译
  7. android 从图片获取二维码
  8. 软件构架实践_阅读笔记01(1-3)
  9. endnote如何导入txt文件_python如何处理txt及excel文件
  10. 收集整理的较为经典的shell脚本合计
  11. Amanda之安装、部署、测试以及优缺点
  12. s5p6818/fs4418系统移植实验二 安装fastboot驱动
  13. 《亲密关系》笔记(1)
  14. canvas 画哆啦A梦头像
  15. LCD1602液晶使用介绍--(完整版)
  16. 对于后台站点的用户活跃度统计 除了记录用户登陆时间进行筛选,还有没有别的方法
  17. 有事务冲突时节点怎么加入MGR集群
  18. 1. A星算法解决修道士与野人问题
  19. 安大计算机学院李炜教授,自动化系年度人物候选 | 李炜
  20. Git撤销本地commit

热门文章

  1. 编译华硕路由器ACRH17源代码小记
  2. 使用终端命令来关闭Mac电脑
  3. JS导出excel表格
  4. SwiftUI Button精品组件之完美的SwiftUI抖动按钮效果(教程含源码)
  5. 暴走漫画系列之高仿淘宝收货地址(附demo)
  6. 常见测试用例设计方法1---等价类划分
  7. 三菱PLC Q系列经典大型12轴Q01U 实际使用中程序,详细中文注释
  8. 企业运维实战--k8s学习笔记.k8s容器资源限制 Metrics-Server部署 图形化监控Dashboard部署 K9S的安装
  9. 企业微信api,企业微信sdk接口
  10. 【数字通信】Matlab实现16QAM调制与解调,判决,误码率计算