Oracle内连接、左外连接、右外连接、全外连接小总结

2023-10-24 06:18

本文主要是介绍Oracle内连接、左外连接、右外连接、全外连接小总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


转载地址:http://liuzidong.iteye.com/blog/892319


转载:Oracle内连接、左外连接、右外连接、全外连接小总结 

数据库版本:Oracle 9i 

连接n个表,至少需要n-1个连接条件。例如:连接三个表,至少需要两个连接条件。 

表TESTA,TESTB,TESTC,各有A, B两列 

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

A.内连接 

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

Sql代码   收藏代码
  1. SELECT *   
  2. FROM TESTA,TESTB  
  3. WHERE TESTA.A=TESTB.A   


B.外连接 

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

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

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

Sql代码   收藏代码
  1. SELECT *  
  2. FROM TESTA   
  3. LEFT OUTER JOIN TESTB   
  4. ON TESTA.A=TESTB.A   


Oracle 支持另一种写法 

Sql代码   收藏代码
  1. SELECT *   
  2. FROM TESTA,TESTB  
  3. WHERE TESTA.A=TESTB.A(+)   


三个表做左外连接 

Sql代码   收藏代码
  1. SELECT *  
  2. FROM TESTA   
  3. LEFT OUTER JOIN TESTB   
  4. ON TESTA.A=TESTB.A  
  5. LEFT OUTER JOIN TESTC  
  6. ON TESTA.A=TESTC.A   


Oracle 支持的另外一种写法 

Sql代码   收藏代码
  1. SELECT *  
  2. FROM TESTA,TESTB,TESTC  
  3. WHERE TESTA.A=TESTB.A(+)  
  4. AND TESTA.A=TESTC.A(+)  



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

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

Sql代码   收藏代码
  1. SELECT *  
  2. FROM TESTA   
  3. RIGHT OUTER JOIN TESTB   
  4. ON TESTA.A=TESTB.A  


Oracle支持的另一种写法 

Sql代码   收藏代码
  1. SELECT *  
  2. FROM TESTA,TESTB  
  3. WHERE TESTA.A(+)=TESTB.A  


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

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

Sql代码   收藏代码
  1. SELECT *   
  2. FROM TESTA   
  3. FULL OUTER JOIN TESTB  
  4. ON TESTA.A=TESTB.A  


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

Sql代码   收藏代码
  1. SELECT  TESTA.*,TESTB.*  
  2. FROM TESTA  
  3. LEFT OUTER JOIN TESTB  
  4. ON TESTA.A=TESTB.A  
  5. UNION  
  6. SELECT TESTA.*,TESTB.*  
  7. FROM TESTB  
  8. LEFT OUTER JOIN TESTA  
  9. ON TESTA.A=TESTB.A  


oracle中的各种连接(join):内连接、外连接、自然连接、自连接、交叉连接 

内连接(inner join)就是将根据检索条件将满足条件的数据选择出来,oracle首先用第一张表的第一条数据去扫描另一张表的所有数据,如果遇到符合条件的数据就加入到结果集中。直到检索完第二张表的所有数据。然后用第一张表的第二条数据,重复刚才的动作,直到以第一张的最后一条数据。其关键字是join,可以使用using关键字和on关键字。oracle中默认的连接是内连接。 

外连接(outer join)是根据需要将表中某些不符合选择条件的数据也列举出来,根据选择标准的不同分为左连接、右连接和满外连接。 

自然连接(natural join)是由oracle自行决定哪些列作为连接的条件。Oracle是这么确定的:将不同表中的那些具有相同名称和数据类型的字段用相等的条件连接起来。 

自连接(self join)中,Oracle将一个表的一个镜像当作另一个表,你可以像使用两个表一样使用这一个表。 

交叉连接(cross join)是两个表的笛卡尔积,即不做任何条件限制,他们的结果集的数据的条数是两个表的数据条数的乘积。 



在使用关键字JOIN进行不同的表连接时:-》使用USING子句指定等值连接中需要用到的列; 

                                    -》使用ON子句指定额外的连接条件; 

                                    -》使用AND增加连接条件;

这篇关于Oracle内连接、左外连接、右外连接、全外连接小总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/273250

相关文章

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi