SQL - 内连接与外连接
PDF下载地址:SQL-内连接与外连接.pdf
连接查询在关系型数据库中经常用到,是多表联合查询的基础。
主要包含:内连接,外连接,交叉连接。

内连接
内连接又分为等值连接,不等值连接,自然连接。
连接查询中使用的比较运算符有:=, >, <, <>, >=, <=, !>, !<
等值连接
等值连接使用”=”来进行比较运算。
请看下面的例子:
| student_id | student_name | class_id |
|---|---|---|
| 1 | aaa | 15 |
| 2 | bbb | 16 |
| 3 | ccc | 17 |
| class_id | class_name |
|---|---|
| 15 | 五班 |
| 16 | 六班 |
| 17 | 七班 |
| 18 | 八班 |
如果需要查出一下内容:
每个学生所对应的班级名称
此时就可用以下sql语句:
SELECT * FROM
T_student ts,T_class tc
WHERE
ts.class_id=tc.class_id
或者:
SELECT * FROM
T_student ts inner join T_class tc
ON
ts.class_id = tc.class_id
查询结果如下:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
结论如下:
等值连接:
若要连接表t1和t2,比较条件为t1.a=t2.a,那么数据库会用t1中a列的所有元素逐个和t2中的a进行比较,如果相等,则输出该行。
至于数据库内部如何实现,我们暂且不去深究。
不等值连接
内连接中,不使用”=”作为比较运算符,就叫不等值连接。
如果需要查询以下内容:
T_student表和T_class表中,class_id字段不相等的所有组合
此时就可用以下sql语句:
SELECT * FROM
T_student ts,T_class tc
WHERE
ts.class_id <> tc.class_id
或者:
SELECT * FROM
T_student ts inner join T_class tc
ON
ts.class_id <> tc.class_id
查询结果如下:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 2 | bbb | 16 | 15 | 六班 |
| 3 | ccc | 17 | 15 | 七班 |
| 1 | aaa | 15 | 16 | 五班 |
| 3 | ccc | 17 | 16 | 七班 |
| 1 | aaa | 15 | 17 | 五班 |
| 2 | bbb | 16 | 17 | 六班 |
| 1 | aaa | 15 | 18 | 五班 |
| 2 | bbb | 16 | 18 | 六班 |
| 3 | ccc | 17 | 18 | 七班 |
结论如下:
不等值连接
若要连接表t1和t2,比较条件为t1.a不等于t2.a,那么数据库会用t1中a列的所有元素逐个和t2中的a进行比较,如果不相等,则输出该行。
自然连接
自然连接是一种特殊的等值连接,和等值连接差不多,区别在于:
自然连接会去掉重复的列;
自然连接要求比较的两个列属性必须相同,等值连接则不需要;
如果需要查出以下内容:
每个学生所对应的班级名称
sql语句和等值连接差不多:
SELECT ts.*,tc.class_name FROM
T_student ts inner join T_class tc
ON
ts.class_id = tc.class_id
查询结果如下:
| student_id | student_name | class_id | class_name |
|---|---|---|---|
| 1 | aaa | 15 | 五班 |
| 2 | bbb | 16 | 六班 |
| 3 | ccc | 17 | 七班 |
由此可见:
自然连接相当于在等值连接的基础上,加了显示的限定条件,从而实现列去重
外连接
外连接又分为左连接,右连接,全连接。
左连接
左连接以左表为基础,显示左表中的所有记录(显示的记录条数=左表中记录的条数)。再用左表中的指定列来和右表中的指定列比较,满足则输出值,不满足则输出NULL
如果需要查出以下内容:
每个学生所对应的班级名称
此时就可用以下sql语句:
SELECT * FROM
T_student ts left join T_class tc
ON
ts.class_id = tc.class_id
查询结果如下:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
但如果T_student表中增加一条字段:
| student_id | student_name | class_id |
|---|---|---|
| 4 | ddd | 20 |
此时再用上一条sql语句查询,则结果变为:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
| 4 | ddd | 20 | NULL |
NULL |
结论如下:
左连接
以左表为基础,显示的记录条数=左表中记录条数。如果左表中选出的字段符合条件则显示,否则显示
NULL
右连接
与左连接恰恰相反。以右表为基础,显示记录的条数=右表中记录条数,然后和左表中的字段比较,符合条件则输出,否则输出NULL。
使用以下sql语句:
SELECT * FROM
T_student ts right join T_class tc
ON
ts.class_id = tc.class_id
查询结果为:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
NULL |
NULL |
NULL |
18 | 八班 |
结论如下:
右连接
以右表为基础,显示记录的条数=右表中记录条数。如果左表中选出的字段符合条件则显示,否则显示
NULL
全连接
全连接类似于左连接和右连接的综合,显示记录的条数=指定比较字段在两个表中的不同种类数。对于空余字段则显示NULL。
使用以下sql语句:
SELECT * FROM
T_student ts full join T_class tc
ON
ts.class_id = tc.class_id
查询结果为:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
NULL |
NULL |
NULL |
18 | 八班 |
但如果T_student表中增加一条字段:
| student_id | student_name | class_id |
|---|---|---|
| 4 | ddd | 20 |
此时再用上一条sql语句查询,则结果变为:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
| 4 | ddd | 20 | NULL |
NULL |
NULL |
NULL |
NULL |
18 | 八班 |
结论如下:
全连接
指定比较字段在两个表中的不同种类数。对于空余字段则显示
NULL。
交叉连接
交叉连接很简单,就是两个表做笛卡尔积。
如果不加where做选择比较,那么显示的记录行数就是两个表行数的乘积。
使用以下sql语句:
SELECT * FROM
T_student cross join T_class
或者:
SELECT * FROM
T_student,T_class
查询结果为:
| student_id | student_name | class_id | class_id | class_name |
|---|---|---|---|---|
| 1 | aaa | 15 | 15 | 五班 |
| 2 | bbb | 16 | 15 | 六班 |
| 3 | ccc | 17 | 15 | 七班 |
| 1 | aaa | 15 | 16 | 五班 |
| 2 | bbb | 16 | 16 | 六班 |
| 3 | ccc | 17 | 16 | 七班 |
| 1 | aaa | 15 | 17 | 五班 |
| 2 | bbb | 16 | 17 | 六班 |
| 3 | ccc | 17 | 17 | 七班 |
| 1 | aaa | 15 | 18 | 五班 |
| 2 | bbb | 16 | 18 | 六班 |
| 3 | ccc | 17 | 18 | 七班 |
如果是有where进行选择,那就先进行笛卡尔积,然后在笛卡尔积的结果中进行选择(效率很差)。
结论如下:
交叉连接
没有
where进行选择,结果为两个表的笛卡尔积
有where进行选择,先做笛卡尔积,在笛卡尔积的结果中进行选择
- Github:@crazyacking,Devin
- 邮箱:crazyacking@gmail.com
SQL - 内连接与外连接的更多相关文章
- 你真的会玩SQL吗?和平大使 内连接、外连接
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化
先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NO ...
- SQL中的连接可以分为内连接,外连接,以及交叉连接 。
SQL中的连接可以分为内连接,外连接,以及交叉连接 . 1. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积: 举例, ...
- 【SQL】SQL中笛卡尔积、内连接、外连接的数据演示
SQL的查询语句中,常使用到内连接.外连接,以及连接的基础--笛卡尔积运算. 在简单的SQL中,也许我们还分辨清楚数据如何连接,一旦查询复杂了,脑子也犯浆糊了,迷迷糊糊的. 本文,简单以数据形式记录连 ...
- 转:SQL的内连接与外连接
参考:http://www.cuiyongjian.com/post-130.html 在oracle的SQL语句常用的连接有内连接(inner join),外连接(outer join)等,内连接又 ...
- SQL的内连接与外连接
转自:http://blog.csdn.net/killerggf/article/details/6216102 有两个表A和表B. 表A结构如下: Aid:int:标识种子,主键,自增ID ...
- SQL Server中内连接和外连接的区别
SQL Server中内连接和外连接的区别 假设一个数据库中有两张表,一张是学生表StudentInfo,一张是班级表ClassInfo,两张表之间用ClassId字段进行关联. 如果用内连接,正常的 ...
- 你真的会玩SQL吗?内连接、外连接
原文:你真的会玩SQL吗?内连接.外连接 大多数人一般写多表查询会这样写select * from tbA ,tbB 没有用到JOIN关键字,太Low了,官网标准建议是用JOIN明确表间的关系,下面 ...
- SQL连接:内连接、外连接、交叉连接。
SQL连接可以分为内连接.外连接.交叉连接. 数据库数据: book表 stu表 1.内连接 ...
随机推荐
- UWP中的Direct2D
介绍 DirectX一直是Windows平台中高性能图形的代名词,自Win7开始,微软又推出了Direct2D技术,包装于Direct3D,但专注于2D图形,并且准备取代GDI这样的传统2D图形技术. ...
- 人人都是 DBA(III)SQL Server 调度器
在 SQL Server 中,当数据库启动后,SQL Server 会为每个物理 CPU(包括 Physical CPU 和 Hyperthreaded)创建一个对应的任务调度器(Scheduler) ...
- Web前端技术研究:Css hack技术---令人沮丧的技术
我最近想好好整理下csshack技术,但是结果很沮丧,下面我将我最初写的笔记和大家分享下. 我在单位整理的研究笔记: 不同的浏览器对某些CSS代码解析会存在一定的差异,因此就会导致不同浏览器下给用户展 ...
- Senparc.Weixin.MP SDK 微信公众平台开发教程(十四):请求消息去重
为了确保信息请求消息的到达率,微信服务器在没有及时收到响应消息(ResponseMessage)的情况下,会多次发送同一条请求消息(RequestMessage),包括MsgId等在内的所有文本内容都 ...
- Bootstrap~表单Form
回到目录 在进行自己的后台改版时,大体布局都使用了bootstrap,剩下的表单部分没理由不去使用它,对于表单的美化和布局,bootstrap做的也是很不错的,有大气的边框,多功能的按钮及宏观的表单布 ...
- EF架构~CodeFirst自关联表的插入
回到目录 这个文章对之前EF的一个补充,对于一些自关联表的添加,如果你建立了表约束确实有这种问题,一般主键为整形自增,父ID为可空,这时,在添加时如果不为ID赋值,结果就会出错. 错误: 无法确定依赖 ...
- 更新日志 - fir.im 新版优化上线
经过这段时间的用户反馈收集和新版本的功能调研,我们对 fir.im Rio 上传下载.应用管理再次做了调整优化.感谢之前内测用户的反馈与建议.目前 fir.im Rio 新版已正式上线,主要优化有以下 ...
- C#设计模式-工厂模式
引入人.工厂.和斧子的问题 原始社会时,劳动社会基本没有分工,需要斧子的人(调用者)只好自己去磨一把斧子,每个人拥有自己的斧子,如果把大家的石斧改为铁斧,需要每个人都要学会磨铁斧的本领,工作效率极低. ...
- Android Studio 使用技巧
1.导入Android Studio 工程的一些技巧 因为Gradle版本的问题,我们在使用AS导入工程的时候,经常会碰到本地没有该项目的Gradle版本,这时候AS就会去下载这个版本的Gradle, ...
- SQL SERVER 查询性能优化——分析事务与锁(五)
SQL SERVER 查询性能优化——分析事务与锁(一) SQL SERVER 查询性能优化——分析事务与锁(二) SQL SERVER 查询性能优化——分析事务与锁(三) 上接SQL SERVER ...