最常用SQL joins:内连接(交集)、左外连接、右外连接、左连接、右连接、全连接(并集),全外连接
1、内连接。两个表的公共部分用Inner join,Inner join是交集的部分。
Select * from TableA A inner join TableB B on A.key=B.key
2、左外连接。A表和B表的共有,加上A的独有,简称全A。
Select * from TableA A left join TableB B on A.key=B.key
红色部分是两表的公有部分,此时8号记录是A表的独有,右边的部门表并没有满足的就用null补齐。
3、右外连接。A表和B表的共有,加上B的独有,简称全B。
Select * from TableA A right join TableB B on A.key=B.key
红色部分是两表的公有部分,右表全部查出来,左表没有满足的就用null补齐。
不管是左连接还是右连接,连接之后表格的高度要一样,不匹配的表全部用null对齐。
4、左连接。A的独有,把公有的去掉,A独占就没B什么事了。
On是join条件。
Select * from TabelA A left join TableB B on A.key=B.key where B.key is null
A表的独占,即B表的Id必定等于null
5、右连接。B的独有,把公有的去掉,B独占就没A什么事了。
Select * from TableA A right join TableB B on A.key=B.key where A.key is null
B表的独占,即A表的id肯定为null、
6、全连接。Full outer join是全连接。
Mysql不支持这种语法,但是oracle支持。
但是!MySQL中并不支持这种写法,所以只能通过别的方法。A、B的所有也就是A的独有、B的独有 和A、B的共同拥有的数据,Mysql中可以使用:
select * from Table A left join Table B on A.Key = B.Key (找出A的所有)
union (去重)
select * from Table A right join Table B on A.Key = B.Key(找出B的所有)
7、全外连接(Mysql中不支持下图写法)。左右表的共有数据之外的数据查询 。各自独有之和,偏偏没有中间部分。
筛选出对于A表而言B为空,对于B表而言A为空的。MySQL中也不支持这种写法,所以只能通过别的方法。其实全外连接也就是A的独有+B的独有。
Mysql语法:
select * from Table A left join Table B on A.Key = B.Key where B.Key is null (找出A的独有)
union (去重)
select * from Table A right join Table B on A.Key = B.Key where A.Key is null (找出B的独有)
最常用SQL joins:内连接(交集)、左外连接、右外连接、左连接、右连接、全连接(并集),全外连接的更多相关文章
- 内连接,外链接(左连接、右连接、全连接),交叉连接大总结+附SQL JOINS图解[转]
1.什么是连接查询呢? 概念:根据两个表或多个表的列之间的关系,从这些表中查询数据. 目的:实现多个表查询操作. 2.分类: 首先划分一下,连接分为三种:内连接.外连接.交叉连接 内连接(INNER ...
- Mysql常用sql语句(16)- inner join 内连接
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 利用条件表达式来消除交叉连接(cross joi ...
- mysql内连接(inner join 找两个表的交集)、左连接(left join 交集并且左表所有)、右连接(right join 交集并且右表所有)、全连接(mysql不支持)
用两个表(a_table.b_table),关联字段a_table.a_id和b_table.b_id来演示一下MySQL的内连接.外连接( 左(外)连接.右(外)连接.全(外)连接). MySQL版 ...
- sql ,内连接,外连接,自然连接等各种连接
1.内联接(典型的联接运算,使用像 = 或 <> 之类的比较运算符).包括相等联接和自然联接. 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 students和c ...
- My SQL的内连接,外链接查询
1.内连接:只连接匹配的行. 2.左外连接:包含左边表的全部行,以及右边表中所有匹配的行,无论右边的表有没有和左边匹配的行,左边的所有行都必须要显示. 3.右外连接:包含右边表的全部行,以及左边表中所 ...
- 【转】SQL中内连接和外连接
如表 ------------------------------------------------- table1 | table2 | ----------------- ...
- SQL Server内连接、外连接、交叉连接
前言 在数据库查询中,我们常常会用到的表连接查询,而我自己在工作中也是时常用这些表连接查询.而就在刚刚我却还没有搞清楚数据库表连接到底有哪几种, 这几种表连接查询方式又有什么区别,实属惭愧!借以此文以 ...
- SQL中内连接和外连接的问题!
本文系转载,版权归原作者所有. 如表 ------------------------------------------------- table1 | table2 | ...
- Mysql常用sql语句(17)- left/right join 外连接
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 外连接分为两种:left join.right ...
随机推荐
- 搭建tdh平台
1.卸载tdh平台(见tdh集群卸载文件夹) 在manager节点执行chmod +x uninstall.sh (非root用户执行sudo chmod +x uninstall.sh)开始卸载TD ...
- AtCoder Beginner Contest 183
第二次ak,纪念一下. 比赛链接:https://atcoder.jp/contests/abc183/tasks A - ReLU 题解 模拟. 代码 #include <bits/stdc+ ...
- [OpenCV]获取摄像头视频
环境:Windows 8 64bit + VS2012 X64 + OpenCV 2.4.7 摄像头的捕捉使用VideoCapture类 Class VideoCapture [OpenCV文档 ...
- HDU4787 GRE Words Revenge【AC自动机 分块】
HDU4787 GRE Words Revenge 题意: \(N\)次操作,每次记录一个\(01\)串或者查询一个\(01\)串能匹配多少个记录的串,强制在线 题解: 在线的AC自动机,利用分块来降 ...
- Find a multiple POJ - 2356
The input contains N natural (i.e. positive integer) numbers ( N <= 10000 ). Each of that numbers ...
- python程序配置守护进程
参考博客 python Supervisor 使用与配置_a35155的博客-CSDN博客 Ubuntu系统下:apt-get install supervisor,通过这种方式安装后,自动设置为开机 ...
- 修改jpg的图片大小
using System.Drawing.Imaging; public void ResizePic(string oldFilePath, int thumbnailImageWidth, int ...
- 爬虫入门二 beautifulsoup
title: 爬虫入门二 beautifulsoup date: 2020-03-12 14:43:00 categories: python tags: crawler 使用beautifulsou ...
- Linux 驱动框架---input子系统
input 子系统也是作为内核的一个字符设备模块存在的,所以他也是字符设备自然也会有字符设备的文件接口.input子系统的注册过程主要分为两步,先注册了一个input class然后再注册一个字符设备 ...
- npm version ^ meaning
npm version ^ meaning ^ 更新版 https://docs.npmjs.com/cli/v6/commands/npm-version https://github.com/ge ...