`
sangei
  • 浏览: 337242 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

(转)join, inner join, left join, right join, full join的区别

阅读更多

inner join可以简写为join

 

连接分为两种:内连接与外连接。

A.内连接

 

内连接,即最常见的等值连接,例:

 

SELECT *

FROM TESTA,TESTB

WHERE TESTA.A=TESTB.A

等价于

select * from testa inner join testb on testa.a=testb.a

 

B.外连接

 

外连接分为左外连接,右外连接和全外连接。

 

1  左外连接 left outer join 或者 left join

 

左外连接就是在等值连接的基础上加上主表中的未匹配数据,例:

 

SELECT *

FROM TESTA

LEFT OUTER JOIN TESTB

ON TESTA.A=TESTB.A

 

其中主表是testa

 

Oracle 中等价于

 

SELECT *

FROM TESTA,TESTB

WHERE TESTA.A=TESTB.A(+)

 

三个表做左外连接

 

SELECT *

FROM TESTA

LEFT OUTER JOIN TESTB

ON TESTA.A=TESTB.A

LEFT OUTER JOIN TESTC

ON TESTA.A=TESTC.A

 

Oracle 中等价于

 

SELECT *

FROM TESTA,TESTB,TESTC

WHERE TESTA.A=TESTB.A(+)

AND TESTA.A=TESTC.A(+)

 

2 右外连接 right outer join 或者 right join

 

右外连接是在等值连接的基础上加上被连接表的不匹配数据

 

SELECT *

FROM TESTA

RIGHT OUTER JOIN TESTB

ON TESTA.A=TESTB.A

 

其中被连接表是testb

Oracle支持的另一种写法

 

 

 

SELECT *

FROM TESTA,TESTB

WHERE TESTA.A(+)=TESTB.A

 

 

 

3.全外连接 full outer join 或者 full join

 

全外连接是在等值连接的基础上将左表和右表的未匹配数据都加上

 

 

 

SELECT *

FROM TESTA

FULL OUTER JOIN TESTB

ON TESTA.A=TESTB.A

 

 

 

全外连接的等价写法,对同一表先做左连接,然后右连接

 

 

 

SELECT  TESTA.*,TESTB.*

FROM TESTA

LEFT OUTER JOIN TESTB

ON TESTA.A=TESTB.A

UNION

SELECT TESTA.*,TESTB.*

FROM TESTB

LEFT OUTER JOIN TESTA

ON TESTA.A=TESTB.A

 

“(+)”所在位置的另一侧为连接的方向

 

分享到:
评论

相关推荐

    inner join、 left join 、right join、 outer join之间的区别

    ### inner join、left join、right join、outer join之间的区别 在数据库操作中,连接(Join)是一种非常重要的操作,用于组合两个或多个表中的数据。根据连接的方式不同,可以分为几种类型:`INNER JOIN`、`LEFT ...

    SQL中的left outer join,inner join,right outer join用法详解

    * FULL OUTER JOIN:LEFT OUTER 和 RIGHT OUTER 中所有行的超集。 内连接(Inner Join) 内连接是最常见的一种连接,它也被称为普通连接,而 E.FCodd 最早称之为自然连接。例如: SELECT * FROM t_institution i ...

    SQL语句inner join,left join ,right join连接的不同之处

    根据连接方式的不同,可以分为多种类型,包括内连接(Inner Join)、左连接(Left Join)以及右连接(Right Join)。本文将详细探讨这三种连接方式的区别,并通过具体的例子来解释它们的应用场景。 ### 内连接...

    Mysql之innerjoin,leftjoin,rightjoin详解.pdf

    Mysql 之 inner join、left join、right join 详解 Mysql 中的连接查询是指从多个表中检索数据,并将它们组合成一个结果集。inner join、left join 和 right join 是 Mysql 中三种最常用的连接查询方式。 inner ...

    关于sql的left join,right join,inner join,outerjoin

    本篇文章将深入探讨四种基本的JOIN类型:LEFT JOIN(左连接)、RIGHT JOIN(右连接)、INNER JOIN(内连接)以及OUTER JOIN(外连接)。我们将详细解释这些概念,它们的工作原理以及在实际数据库操作中的应用。 1. ...

    SQL表连接查询(inner join、full join、left join、right join)1

    在SQL中,主要有四种类型的连接查询:内连接(INNER JOIN)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)和全连接(FULL JOIN)。下面将详细解释这四种连接方式。 1. 内连接(INNER JOIN): 内连接返回两个表中...

    join on 语句及扩展

    3. RIGHT JOIN (或 RIGHT OUTER JOIN): 右JOIN与LEFT JOIN相反,返回右表的所有记录,即使左表中没有匹配的记录。左表中未找到匹配项的记录将用NULL填充。语法: ```sql SELECT columns FROM table1 RIGHT JOIN ...

    MySQL JOIN 语法说明与 INNER JOIN 语法用法实例.docx

    本文档详细介绍了 MySQL 中的 JOIN 语法,包括 INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN 等,并提供了实际的实例来说明 JOIN 的用法。 首先,MySQL 的 JOIN 语法用于根据两个或多个表中的字段之间的关系,从...

    sql join( inner join, outer join) 分析

    接下来,我们讨论OUTER JOIN,它分为LEFT JOIN、RIGHT JOIN和FULL JOIN。OUTER JOIN的目的是返回所有匹配的行以及至少一方表中的非匹配行。 - LEFT JOIN(或LEFT OUTER JOIN)返回左表中的所有行,即使右表中没有...

    inner join and outer join.pdf

    #### 四、Left Outer Join 与 Right Outer Join 的区别 - **Left Outer Join** 返回左表(第一个表)的所有记录,以及右表中与之匹配的记录。如果右表中没有匹配记录,则返回 NULL。 - **Right Outer Join** 返回右...

    left join 过滤条件写在on后面和写在where 后面的区别

    ### left join 过滤条件写在on后面和写在where 后面的区别 在SQL查询语句中,连接(JOIN)是一种非常重要的操作,用于从两个或多个表中获取数据。其中,`LEFT JOIN`是一种常用的连接类型,它返回左表的所有记录以及...

    SQL中inner join、outer join和cross join的区别

    根据不同的连接方式,`JOIN`可以分为几种类型,包括`INNER JOIN`、`OUTER JOIN`(左外联接`LEFT JOIN`、右外联接`RIGHT JOIN`以及全外联接`FULL JOIN`)和`CROSS JOIN`。每种类型的`JOIN`都有其独特的应用场景和特点。...

    oracle-join用法

    在Oracle SQL中,Join主要分为几个类型,包括INNER JOIN、LEFT JOIN (LEFT OUTER JOIN)、RIGHT JOIN (RIGHT OUTER JOIN)以及FULL JOIN (FULL OUTER JOIN)。这些类型在Java编程中同样可以使用,通过SQL查询语句来实现...

    SQL联合查询inner join、outer join和cross join的区别详解

    这三者的区别很多人都应该不是很清楚,包括我自己,下面我们一起来看看,如果你使用join连表,缺陷的情况下是inner join,另外,开发中使用的left join和right join属于outer join,而outer join还包括full join....

    sql中join总结

    2. **内JOIN (INNER JOIN)**: 内JOIN返回两个表格中满足特定条件的匹配记录。在上述例子中,`ON a.id = b.id`表示只选取`A_test`的`id`与`B_test`的`id`相等的记录。这将过滤掉交叉JOIN中的不匹配记录,得到一个更...

    inner join-outer join-cross join查询方式总结

    根据连接方式的不同,可以分为内连接(INNER JOIN)、外连接(LEFT JOIN、RIGHT JOIN 和 FULL JOIN)以及交叉连接(CROSS JOIN)。下面我们将详细探讨每种连接方式的特点、适用场景及其具体的实现方法。 #### 内...

    【SQL高级(三)】【SQL 连接(JOIN)】

    文章目录SQL 连接(JOIN)不同的 SQL JOINSQL INNER JOIN 关键字SQL LEFT JOIN 关键字SQL RIGHT JOIN 关键字SQL FULL OUTER JOIN 关键字 SQL 连接(JOIN) SQL join 用于把来自两个或多个表的行结合起来。 下图展示了 ...

    mysql Join使用以及优化

    基本的Join类型包括INNER JOIN、LEFT JOIN、RIGHT JOIN和FULL JOIN等。 INNER JOIN仅返回两个表中匹配的记录,而LEFT JOIN、RIGHT JOIN和FULL JOIN分别返回左表、右表以及两个表中所有的记录,即使某些记录在另一表...

Global site tag (gtag.js) - Google Analytics