在ORACLE数据库中,表与表之间的SQL JOIN方式有多种(不仅表与表,还可以表与视图、物化视图等联结)。SQL JOIN其实是一个逻辑概念,像NEST LOOP JOIN、 HASH JOIN等是表连接的物理实现方式。

为了更直观的了解以上join方式,我们通过俩个测试表来进行测试,首先是建表语句:

create table U (
name varchar2(20),
gender varchar2(10)
);
create table D(
name varchar2(20),
sal number(6,0)
); insert into U values('tom','male'); insert into U values('jerry','male'); insert into U values('tina','female'); insert into U values('ying','female');
COMMIT; insert into D
select 'ying',10000 from dual union all
select 'tom',5000 from dual union all
select 'sam',3000 from dual union all
select 'jeck',4500 from dual;
COMMIT;

内连接:INNER JOIN

内连接:也称为等值连接,返回两张表都满足条件的部分

注释:inner join 就等于 join

inner join 表示返回俩个表或记录连接字段的匹配记录。它有三种实现方式,如下图所示:

select U.NAME,U.GENDER,D.SAL
from U inner join D on U.NAME = D.NAME; 我的报表 1
NAME GENDER SAL
---------------------------------------- -------------------- ----------
ying female 10000
tom male 5000
select u.name,u.gender,d.sal
from u,d
where u.name=d.name; 我的报表 1
NAME GENDER SAL
---------------------------------------- -------------------- ----------
ying female 10000
tom male 5000
select name, u.gender,d.sal
from u inner join d using(name); 我的报表 1
NAME GENDER SAL
---------------------------------------- -------------------- ----------
ying female 10000
tom male 5000

注意:inner join 可以使用简写join方式,如下所示,但是建议使用inner join。

select u.name,u.gender,d.sal
from u join d
on u.name=d.name; 我的报表 1
NAME GENDER SAL
---------------------------------------- -------------------- ----------
ying female 10000
tom male 5000 select name ,u.gender,d.sal
from u join d using(name); 我的报表 1
NAME GENDER SAL
---------------------------------------- -------------------- ----------
ying female 10000
tom male 5000

外链接:OUTER JOIN

外连接分为外左连接(left outer join)和外右连接(right outer join)

注释:left outer join 与 left join 等价, 一般写成left join

right outer join 与 right join等价,一般写成right join

1.全连接:full join

全外连接是在结果中除了显示满足连接的条件的行外,还显示了join两侧表中所有满足检索条件的行

全连接:包含左、右俩个表的所有行,不管另一表中是否存在与其匹配的行。不符合条件的,则以空值代替。如下所示:

select u.name,u.gender,d.name,d.sal
from u full join d
on
u.name=d.name 我的报表 1
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
ying female ying 10000
tom male tom 5000
sam 3000
jeck 4500
tina female
jerry male

FULL OUTER JOIN的韦恩图如下:

2.左外连接:LEFT JOIN

左连接,取左边的表的全部,右边的表按条件,符合的显示,不符合则显示null

举例:select <select list> from A left join B on A.id=B.id

LEFT OUTER JOIN (with common data)韦恩图如下:

上面是左外连接(带公共数据)的查询方法,那么还有一种就是不包含的,表示如下:

左外连接:又叫左连接,意思是包含左边表所有记录,右边所有匹配的记录,如果没有则用空补齐。换句话说就是,列出左边表全部的,及右边表符合条件的,不符合条件的以空值代替。

select u.name,u.gender,d.name,d.sal
from u left join d
on u.name=d.name; 我的报表 1
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
ying female ying 10000
tom male tom 5000
tina female
jerry male select u.name,u.gender,d.name,d.sal
from u,d
where u.name = d.name(+); 我的报表 1
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
ying female ying 10000
tom male tom 5000
tina female
jerry male

3.右外连接:RIGHT JOIN

右连接:取右边的表的全部,左边的表按条件,符合的显示,不符合则显示null

举例:select <select list> from A right join B on A.id=B.id

右外连接:又叫右链接,意思是包括右边表所有记录,匹配左边表的记录,如果没有则以空补齐。换句话说,列出右边全部的,及左边符合条件的,不符合条件的则以空值代替。

select u.name,u.gender,d.name,d.sal
from u right join d
on u.name = d.name; 我的报表 1
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
tom male tom 5000
ying female ying 10000
jeck 4500
sam 3000 select u.name,u.gender,d.name,d.sal
from u,d
where u.name(+)=d.name; 我的报表 1
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
tom male tom 5000
ying female ying 10000
jeck 4500
sam 3000

交叉连接(CROSS JOIN)

交叉连接:返回左表中的所有行,左表中的每一行与右表中的所有行组合。交叉联接也称作笛卡尔积

笛卡尔积

笛卡尔乘积是指在数学中,两个集合X和Y的笛卡尓积(Cartesian product),又称直积,表示为X × Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员

举例:

现在,我们有两个集合A和B。

A = {0,1} B = {2,3,4}

集合 A×B 和 B×A的结果集就可以分别表示为以下这种形式:

A×B = {(0,2),(1,2),(0,3),(1,3),(0,4),(1,4)};

B×A = {(2,0),(2,1),(3,0),(3,1),(4,0),(4,1)};

以上A×B和B×A的结果就可以叫做两个集合相乘的‘笛卡尔积’。

从以上的数据分析我们可以得出以下两点结论:

1,两个集合相乘,不满足交换率,既 A×B ≠ B×A;

2,A集合和B集合相乘,包含了集合A中元素和集合B中元素相结合的所有的可能性。既两个集合相乘得到的新集合的元素个数是 A集合的元素个数 × B集合的元素个数;

交叉连接两种写法

交叉连接有两种,显式的和隐式的,不带ON子句,返回的是两表的乘积,也叫笛卡尔积。

例如:下面的语句1和语句2的结果是相同的。

语句1:隐式的交叉连接,没有CROSS JOIN。

SELECT O.ID, O.ORDER_NUMBER, C.ID, C.NAME
FROM ORDERS O , CUSTOMERS C
WHERE O.ID=1;

语句2:显式的交叉连接,使用CROSS JOIN。

SELECT O.ID,O.ORDER_NUMBER,C.ID,
C.NAME
FROM ORDERS O CROSS JOIN CUSTOMERS C
WHERE O.ID=1;
select * from u cross join d;

              我的报表                     1
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
tom male ying 10000
tom male tom 5000
tom male sam 3000
tom male jeck 4500
jerry male ying 10000
jerry male tom 5000
jerry male sam 3000
jerry male jeck 4500
tina female ying 10000
tina female tom 5000
tina female sam 3000 我的报表 2
NAME GENDER NAME SAL
---------- -------------------- ---------- ----------
tina female jeck 4500
ying female ying 10000
ying female tom 5000
ying female sam 3000
ying female jeck 4500

Oracle SQL中join方式总结的更多相关文章

  1. SQL Server Join方式

    原文:SQL Server Join方式 0.参考文献 Microsoft SQL Server企业级平台管理实践 看懂SqlServer查询计划 1.测试数据准备 参考:Sql Server中的表访 ...

  2. Oracle SQL中实现indexOf和lastIndexOf功能

    Oracle SQL中实现indexOf和lastIndexOf功能 https://www.2cto.com/database/201305/210470.html

  3. Oracle sql 优化の常用方式

    1.不要用 '*' 代替所有列名,特别是字段比较多的情况下 使用select * 可以列出某个表的所有列名,但是这样的写法对于Oracle来说会存在动态解析问题.Oracle系统通过查询数据字典将 ' ...

  4. 关于sql中join

    对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚.Codin ...

  5. Oracle sql 中的字符(串)替换与转换[转载]

    1.REPLACE 语法:REPLACE(char, search_string,replacement_string) 用法:将char中的字符串search_string全部转换为字符串repla ...

  6. 【总结】Oracle sql 中的字符(串)替换与转换

    1.REPLACE 语法:REPLACE(char, search_string,replacement_string) 用法:将char中的字符串search_string全部转换为字符串repla ...

  7. SQL中join和cross join的区别

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

  8. my sql中join的操作

    SQL标准中的Join的类型:  首先,设置表employees和department的数据为:  1.inner join … on操作类型 内连接inner join是基于连接谓词将两张表(如A和 ...

  9. SQL中JOIN 的用法

    关于sql语句中的连接(join)关键字,是较为常用而又不太容易理解的关键字,下面这个例子给出了一个简单的解释 --建表table1,table2:create table table1(id int ...

随机推荐

  1. PTA 银行排队问题之单队列多窗口服务 (25分)

    PTA 银行排队问题之单队列多窗口服务 (25分) 假设银行有K个窗口提供服务,窗口前设一条黄线,所有顾客按到达时间在黄线后排成一条长龙.当有窗口空闲时,下一位顾客即去该窗口处理事务.当有多个窗口可选 ...

  2. 【GIS】GeoServer服务Authkey配置记录

    特别感谢:https://www.cnblogs.com/HandyLi/p/8624507.html 1.服务受控配置 2.授权方式 3.Url模式配置 4.Authkey密钥配置 5.使用 在wm ...

  3. No versions available for io.grpc:grpc-core:jar:[1.13.1] within specified range

    No versions available for i{0}:[1.13.1] within specified range maven打包的时候报错是由于同一个jar包有多个版本导致的版本冲突 解决 ...

  4. GoLang设计模式14 - 状态模式

    状态模式,顾名思义,是一种基于有限状态机制的设计模式.在这种设计模式中,行为是由相应的状态来决定的.接下来我们会用一个售卖机的例子来说明下状态模式.为了便于说明,我们把场景简化一下,假设有一台售卖机只 ...

  5. Django笔记&教程 3-3 模板常用语法

    Django 自学笔记兼学习教程第3章第3节--模板常用语法 点击查看教程总目录 本文主要参考:https://docs.djangoproject.com/en/2.2/ref/templates/ ...

  6. ajax的get方法获取豆瓣电影前10页的数据

    # _*_ coding : utf-8 _*_ # @Time : 2021/11/2 11:45 # @Author : 秋泊酱 # 1页数据 电影条数20 # https://movie.dou ...

  7. springboot和springcloud版本上的选择

    现在的springboot项目和cloud版本都是更新很快,但我们开发不是版本越新越好,我们要把版本对应起来,那么我们怎么去关联呢? springboot和springcloud不是越新越好,clou ...

  8. try catch引发的性能优化深度思考

    关键代码拆解成如下图所示(无关部分已省略): 起初我认为可能是这个 getRowDataItemNumberFormat 函数里面某些方法执行太慢,从 formatData.replace 到 une ...

  9. 【.NET 与树莓派】MPD 的 Mini-API 封装

    在前面的水文中,一方面,老周向各位同学介绍了通过 TCP 连接来访问 MPD 服务:另一方面,也简单演示了 ASP.NET Core 的"极简 API"(Mini API).本篇老 ...

  10. Codeforces 356E - Xenia and String Problem(哈希)

    Codeforces 题面传送门 & 洛谷题面传送门 首先显然一个 gray 串的长度只可能是 \(2^k-1\),其中 \(k\in\mathbb{Z}\). 考虑将一个字符改成另外一个字符 ...