SQL - 内连接与外连接

PDF下载地址:SQL-内连接与外连接.pdf

连接查询在关系型数据库中经常用到,是多表联合查询的基础。
主要包含:内连接外连接交叉连接


  • SQL - 内连接与外连接

    • 内连接

      • 等值连接
      • 不等值连接
      • 自然连接
    • 外连接
      • 左连接
      • 右连接
      • 全连接
    • 交叉连接

内连接

内连接又分为等值连接不等值连接自然连接

连接查询中使用的比较运算符有:=, >, <, <>, >=, <=, !>, !<

等值连接

等值连接使用”=”来进行比较运算。
请看下面的例子:

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 tcWHERE    ts.class_id=tc.class_id

或者:

SELECT * FROM    T_student ts inner join T_class tcON    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 tcWHERE    ts.class_id <> tc.class_id

或者:

SELECT * FROM    T_student ts inner join T_class tcON    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 tcON    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 tcON    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 tcON    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 tcON    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进行选择,先做笛卡尔积,在笛卡尔积的结果中进行选择



时间: 2024-08-08 09:27:57

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

详解SQL Server连接(内连接、外连接、交叉连接)

在查询多个表时,我们经常会用“连接查询”.连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志. 什么是连接查询呢? 概念:根据两个表或多个表的列之间的关系,从这些表中查询数据. 目的:实现多个表查询操作. 知道了连接查询的概念之后,什么时候用连接查询呢? 一般是用作关联两张或两张以上的数据表时用的.看起来有点抽象,我们举个例子,做两张表:学生表(T_student)和班级表(T_class). T_student                            

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

SQL连接可以分为内连接.外连接.交叉连接. 数据库数据:             book表                                          stu表 1.内连接 1.1.等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列. 1.2.不等值连接:在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值.这些运算符包括>.>=.<=.<.!>.!<和<&g

SQL连接(内连接、外连接、交叉连接)

SQL连接(内连接.外连接.交叉连接) 假设现在有两个表:table1 , table2 table1:                                table2 :  id      name                          id      score    1       lee                            1        90    2       zhang                         2        

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

SQL的查询语句中,常使用到内连接.外连接,以及连接的基础--笛卡尔积运算. 在简单的SQL中,也许我们还分辨清楚数据如何连接,一旦查询复杂了,脑子也犯浆糊了,迷迷糊糊的. 本文,简单以数据形式记录连接的数据结果,在迷糊时可翻阅. 以MySQL运行. > 原始的表 select * from t_user u; select * from t_address a; select * from t_phone p; > 笛卡尔积 select * from t_user, t_address;

转:SQL的内连接与外连接

参考:http://www.cuiyongjian.com/post-130.html 在oracle的SQL语句常用的连接有内连接(inner join),外连接(outer join)等,内连接又包括等值连接,非等值连接,自连接:而外连接又分为左连接和右连接.其中默认的是内连接的等值连接. 为了方便我们创建两张最简易的表A.B,具体的表结构参看下面,来分析内连接与外连接的区别 图1 图2 两个表要做连接,必须要有连接字段,而在表A和表B中连接字段是Aid和Bnamid,下图说明了连接之间关系

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

原文:你真的会玩SQL吗?内连接.外连接 大多数人一般写多表查询会这样写select * from tbA ,tbB  没有用到JOIN关键字,太Low了,官网标准建议是用JOIN明确表间的关系,下面具体来讲. 连接类型: 交叉联接 得到所连接表的所有组合 (笛卡儿集)cross join 内联接得到连接表的满足条件的记录组合inner join  on 外联接(左.右)得到一个表的所有行,及其余表满 足连接条件的行 full | left | right  outer join  on 交叉联

[转]深入理解SQL的四种连接-左外连接、右外连接、内连接、全连接

深入理解SQL的四种连接-左外连接.右外连接.内连接.全连接 1.内连接(典型的连接运算,使用像 =  或 <> 之类的比较运算符).包括相等连接和自然连接.     内连接使用比较运算符根据每个表共有的列的值匹配两个表中的行.例如,检索 students和courses表中学生标识号相同的所有行.       2.外连接.外连接可以是左向外连接.右向外连接或完整外部连接.     在 FROM子句中指定外连接时,可以由下列几组关键字中的一组指定:     1)LEFT  JOIN或LEFT

SQL Fundamentals || 多表查询(内连接,外连接(LEFT|RIGHT|FULL OUTER JOIN),自身关联,ON,USING,集合运算UNION)

一.多表查询基本语法 在进行多表连接查询的时候,由于数据库内部的处理机制,会产生一些“无用”的数据,而这些数据就称为笛卡尔积. 多表查询时可以利用等值关联字段消除笛卡尔积 多表查询之中,每当增加一个关联表都需要设置消除笛卡尔积的条件 分析过程很重要: 确定所需要的数据表 确定已知的关联字段: 按照SQL语句的执行步骤编写:FROM,WHERE,SELECT,ORDER BY (由于SELECT是在WHERE子句之后执行,所以SELECT子句所定义的别名WHERE不可以直接使用) (由于SELEC

SQL的内连接与外连接

有两个表A和表B. 表A结构如下: Aid:int:标识种子,主键,自增ID Aname:varchar 数据情况,即用select * from A出来的记录情况如下图1所示: 表B结构如下: Bid:int:标识种子,主键,自增ID Bnameid:int 数据情况,即用select * from B出来的记录情况如下图2所示:图2:B表数据 为了把Bid和Aid加以区分,不让大家有误解,所以把Bid的起始种子设置为100. 有SQL基本知识的人都知道,两个表要做连接,就必须有个连接字段,从