【SQL】连接 —— 内连接、外连接、左连接、右连接、交叉连接
连接
· 内连接
· 外连接
· 左连接
· 右连接
· 全连接
· 交叉连接
· 匹配符号(+)
连接
根据表之间的关系,呈现跨表查询的结果。
| 外连接 | |||||
| 内连接 | 左连接 | 右连接 | 全连接 | 交叉连接 | |
| 基准 | 左表 | 右表 | |||
| 显示数据 | 两表公共部分 |
左表全部 右表满足条件部分 无显示NULL |
右表全部 左表满足条件部分 无显示NULL |
左右表全部 无显示NULL |
两表所有行的组合 (笛卡尔积) |
| 关键词 | (inner) join |
(left) join |
(right) join |
full (outer) join |
cross join |
| 语法简述 | A join B on 条件 | A left join B on 条件 | A right join B on 条件 | A full join B on 条件 | A cross join B on 条件 |
就表A、表B示例
| Aid | name | age |
| 1 | Mary | 22 |
| 2 | Jack | 20 |
| Aid | name |
| 1 | Jack |
| 2 | Ma |
内连接
- 等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。
- 不等值连接:在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>。
- 自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。
获取两表的公共部分
select * from A (inner) join B on A.name = B.name (显性内连接)
select * from A where A.name = B.name (隐性外连接)
| A_Aid | A_name | A_age | B_Bid | B_name1 |
| 1 | Jack | 22 | 1 | Jack |
外连接
左连接
以左表为基准,左表数据全部返回,右表数据只满足where条件,无显示NULL
select * from A left (outer) join B on A.name = B.name 均为全表扫描
select * from A where A.name = B.name (+) A为全表扫描,B为索引扫描,效率稍高
| A_Aid | A_name | A_age | B_Bid | B_name1 |
| 1 | Jack | 22 | 1 | Jack |
| 2 | Mary | 20 | NULL | NULL |
右连接
以右表为基准,右表数据全部返回,左表只返回满足条件的,无显示NULL
select * from A right (outer) join B on A.name = B.name
select * from A where A.name(+) = B.name
| A_Aid | A_name | A_age | B_Bid | B_name1 |
| 1 | Jack | 22 | 1 | Jack |
| NULL | NULL | NULL | 2 | Ma |
全连接
显示两表全部数据,完整外部联接返回左表和右表中的所有行。
当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。
如果表之间有匹配行,则整个结果集行包含基表的数据值。
select * from A full (outer) join B on A.name = B.name
| A_Aid | A_name | A_age | B_Bid | B_name1 |
| 1 | Jack | 22 | 1 | Jack |
| 2 | Mary | 20 | NULL | NULL |
| NULL | NULL | NULL | 2 | Ma |
交叉连接
将两个表的所有行进行组合,连接后的行数为两个表的乘积数。(笛卡尔积)
select * from A cross join B
| A_Aid | A_name | A_age | B_Bid | B_name1 |
| 1 | Jack | 22 | 1 | Jack |
| 1 | Jack | 22 | 2 | Ma |
| 2 | Mary | 20 | 1 | Jack |
| 2 | Mary | 20 | 2 | Ma |
匹配符号
对于外连接, 也可以使用“(+) ”来表示。 关于使用(+)的一些注意事项:
1.(+)操作符只能出现在where子句中,并且不能与outer join语法同时使用。
2. 当使用(+)操作符执行外连接时,如果在where子句中包含有多个条件,则必须在所有条件中都包含(+)操作符
3.(+)操作符只适用于列,而不能用在表达式上。
4.(+)操作符不能与or和in操作符一起使用。
5.(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。
一句话记忆:+号在哪里,就是匹配表
【SQL】连接 —— 内连接、外连接、左连接、右连接、交叉连接的更多相关文章
- [转] 如何设置双网卡同时连接内网外网_bpao_新浪博客
已剪辑自: http://blog.sina.com.cn/s/blog_5d3e229c0100skwe.html 如何设置双网卡同时连接内网外网 . 通过无线网络连接外网,确保连接成功后开始第二步 ...
- SQL-内连接、外连接(左、右)、交叉连接
本文测试基于以下两个表,student(左) \ teacher(右),使用数据库MariaDB,图形化界面HeidiSQL. 连接查询的概念:根据两个表或多个表的列之间的关系,从这些表中查询数据,即 ...
- 配置windows路由表,使电脑同时连接内网外网方法
1.环境一(系统:windows xp,内网.外网不是同一类地址,内网地址固定): 外网:通过笔记本的无线网卡连接: 内网:通过笔记本的本地连接: 第一步,连接网线,配置本地连接地址,注意IP地址不要 ...
- 【转】配置windows路由表,使电脑同时连接内网外网方法
1. 公司内部,内网和外网的网关不一样,怎么样让电脑可以同时上内网和外网呢? 来一张不相关的磁盘结构图: ----------------------------------------------- ...
- C++ class内的 ++ 重载,左++,右++,重载示例。
#include <iostream> // overloading "operator ++ " inside class // ++ 是一元操作符 //////// ...
- SQL: 左连接,右连接,内连接,左外连接,右外连接,完全连接
例子: ---------------------- --------------------------- a表 id name b表 id job parent_id 1 张三 ...
- 【转】SQL中内连接和外连接
如表 ------------------------------------------------- table1 | table2 | ----------------- ...
- SQL中内连接和外连接的问题!
本文系转载,版权归原作者所有. 如表 ------------------------------------------------- table1 | table2 | ...
- SQL Server中的连接查询【内连接,左连接,右连接,。。。】
在查询多个表时,我们经常会用“连接查询”.连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志. 什么是连接查询呢? 概念:根据两个表或多个表的列之间的关系,从这些表中查询数据 ...
- SQL Server内连接、外连接、交叉连接
前言 在数据库查询中,我们常常会用到的表连接查询,而我自己在工作中也是时常用这些表连接查询.而就在刚刚我却还没有搞清楚数据库表连接到底有哪几种, 这几种表连接查询方式又有什么区别,实属惭愧!借以此文以 ...
随机推荐
- CF446B DZY Loves Modification 优先队列
As we know, DZY loves playing games. One day DZY decided to play with a n × m matrix. To be more pre ...
- 不要忽视Web编程中的小细节
概述:长时间以来,我们创造了某些在构造和范围内用以提升网站易用性的约定和实践.然后在我们进行web编程的时候总有一些疏忽和纰漏.这里总结了一些web编程时容易出现的小错误,并给出了相应的补救方法,希望 ...
- BZOJ 3796 Mushroom追妹纸 哈希+二分(+KMP)
先把两个串能匹配模式串的位置找出来,然后标记为$1$(标记在开头或末尾都行),然后对标记数组求一个前缀和,这样可以快速查到区间内是否有完整的一个模式串. 然后二分子串(答案)的长度,每次把长度为$md ...
- BZOJ 1500 [NOI2005]维修数列 FHQ Treap
终于A了这题...这题还是很好...但是我太菜...重构了三遍qwq FHQ Treap大法好!qwq...~~ Ins:直接拿输入造一棵树,把原来的树split成[1,pos],[pos+1,n], ...
- 使用spring boot admin
spring boot admin管理端, 需要部署成独立的应用 pom中添加依赖 <dependency> <groupId>de.codecentric</group ...
- 高可用数据同步方案-SqlServer迁移Mysql实战
简介 随着业务量的上升,以前的架构已经不满足业务的发展,数据作为业务中最重要的一环,需要有更好的架构作为支撑.目前我司有sql server转mysql的需求,所以结合当前业务,我挑选了阿里云开源的一 ...
- ASP Session的功能的缺陷以及解决方案
转http://www.cnblogs.com/jhy55/p/3376925.html 目前ASP的开发人员都正在使用Session这一强大的功能,但是在他们使用的过程中却发现了ASP Sessio ...
- python类型之间的转换
*int(x,base=10)x字符串或数字,base进制数,默认十进制 浮点转为整数 *float 整数转换为浮点型 *complex(1,2) 转换为复数 *str(10)将对象转换为字符串 *r ...
- python_3 :用python微信跳一跳
[学习使用他人代码] 2018年01月21日 19:29:02 独行侠的守望 阅读数:319更多 个人分类: Python 编辑 版权声明:本文为博主原创文章,转载请注明文章链接. https://b ...
- Mongodb简介及基本操作
一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性 ...