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进行选择,先做笛卡尔积,在笛卡尔积的结果中进行选择



 
 

SQL - 内连接与外连接的更多相关文章

  1. 你真的会玩SQL吗?和平大使 内连接、外连接

    你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...

  2. mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化

    先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NO ...

  3. SQL中的连接可以分为内连接,外连接,以及交叉连接 。

    SQL中的连接可以分为内连接,外连接,以及交叉连接 . 1. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积: 举例, ...

  4. 【SQL】SQL中笛卡尔积、内连接、外连接的数据演示

    SQL的查询语句中,常使用到内连接.外连接,以及连接的基础--笛卡尔积运算. 在简单的SQL中,也许我们还分辨清楚数据如何连接,一旦查询复杂了,脑子也犯浆糊了,迷迷糊糊的. 本文,简单以数据形式记录连 ...

  5. 转:SQL的内连接与外连接

    参考:http://www.cuiyongjian.com/post-130.html 在oracle的SQL语句常用的连接有内连接(inner join),外连接(outer join)等,内连接又 ...

  6. SQL的内连接与外连接

    转自:http://blog.csdn.net/killerggf/article/details/6216102 有两个表A和表B.  表A结构如下:  Aid:int:标识种子,主键,自增ID   ...

  7. SQL Server中内连接和外连接的区别

    SQL Server中内连接和外连接的区别 假设一个数据库中有两张表,一张是学生表StudentInfo,一张是班级表ClassInfo,两张表之间用ClassId字段进行关联. 如果用内连接,正常的 ...

  8. 你真的会玩SQL吗?内连接、外连接

    原文:你真的会玩SQL吗?内连接.外连接 大多数人一般写多表查询会这样写select * from tbA ,tbB  没有用到JOIN关键字,太Low了,官网标准建议是用JOIN明确表间的关系,下面 ...

  9. SQL连接:内连接、外连接、交叉连接。

    SQL连接可以分为内连接.外连接.交叉连接. 数据库数据:             book表                                          stu表 1.内连接 ...

随机推荐

  1. Newtonsoft.Json中的时间格式详解.

    Newtonsoft.json是一款不错的序列化反序列化第三方组件,具体如何使用属于基础知识,此处不再讲解.看以下代码: public class OutgameEntity { public str ...

  2. nw.js 软件推荐:AxeSlide斧子演示:PPT的另一种可能(转)

    AxeSlide斧子演示:PPT的另一种可能       一款简单有趣的演示文稿制作软件     AxeSlide斧子演示(www.axeslide.com),是一款简单有趣的演示文稿制作软件,基于H ...

  3. Java提高篇(三二)-----List总结

    前面LZ已经充分介绍了有关于List接口的大部分知识,如ArrayList.LinkedList.Vector.Stack,通过这几个知识点可以对List接口有了比较深的了解了.只有通过归纳总结的知识 ...

  4. Unity3d热更新全书-加载(一)从AssetBundle说起

    Unity3D动态下载资源,有没有解?有,AssetBundle就是通用解,任何一本书都会花大幅篇章来介绍AssetBundle. 我们也来说说AssetBundle 我们试全面的分析一下Unity3 ...

  5. vmware安装ubuntu12.04嵌套安装xen server(实现嵌套虚拟化)

    环境准备 软件:vmware workstation 9.0    ubuntu-12.04.2-server-amd64(官方下载) 硬件:确认CPU支持虚拟化VM-T vmware设置 vmwar ...

  6. IOS Socket 04-利用框架CocoaAsyncSocket实现客户端/服务器端

    这篇文章,我们介绍CocoaAsyncSocket框架的使用,主要介绍实现客户端/服务器端代码,相信在网上已经很多这样的文章了,这里做一下自己的总结.这里介绍使用GCD方式 一.客户端 1.下载地址 ...

  7. git 操作简明扼要,命令不需要多,够用就行

    提升能力最快的方法就是做项目. 从前使用svn时,最开始是自己看网上教程,只会一个从服务端checkout文件,update一下,commit一下,后来使用到了分支,感觉好了不少,感觉svn还挺不错的 ...

  8. ASPNET MVC中断请求

    ASPNET MVC如何正确的中断请求? 感觉是这样? 在aspnet开发过程中如果想要中断当前的http处理,以前在aspnet中一直是Response.End(); 在这Response.End( ...

  9. OOM异常产生的原因和处理方法

    一般而言,android中常见的原因主要有以下几个: 1.数据库的cursor没有关闭. 2.构造adapter没有使用缓存contentview. 3.调用registerReceiver()后未调 ...

  10. seajs模块化开发

    seajs是一个起辅助作用的库,所以它可以更方便开发,而它可以解决以下问题: 1.命名问题,就是冲突 2.性能问题,就是只要一个功能,但却使用一个大插件中的一个小功能,所以要手动拆分出这个功能 3.j ...