oracle 建表id自增长_oracle 左连接、右连接、全外连接、内连接、以及 (+) 号用法...

Oracle中的连接可分为,内连接(INNER JOIN)、外连接(OUTER JOIN)、全连接(FULL JOIN),不光是 Oracle,其他很多的数据库也都有这3种连接查询方式。

Oracle 外连接(OUTER JOIN),又分为左外连接和右外连接,即左连接和右连接。

左外连接 LEFT OUTER JOIN == 左连接 LEFT JOIN(左边的表不加限制)

右外连接 RIGHT OUTER JOIN == 右连接 RIGHT JOIN(右边的表不加限制)

全外连接 FULL OUTER JOIN == 全连接 FULL JOIN(左右两表都不加限制)

注意:通常写 SQL 的时候会省略 OUTER 关键字。

在左连接和右连接时都会以一张 A 表为基础表,该表的内容会全部显示,然后加上 A 表和 B 表匹配的内容。 如果 A 表的数据在 B 表中没有记录。 那么在相关联的结果集行中列显示为空值(NULL)。

对于外连接,也可以使用 "(+)" 操作符来表示。使用时的一些注意事项:

1. 操作符只能出现在 WHERE 子句中,并且不能与 OUTER JOIN 语法同时使用;

2. 操作符执行外连接时,如果在 WHERE 子句中包含有多个条件,则必须在所有条件中都包含 (+) 操作符;

3. 操作符只适用于列,而不能用在表达式上;

4. 操作符不能与 OR 和 IN 操作符一起使用;

5. 操作符只能用于实现左外连接和右外连接,而不能用于实现全外连接;

SELECT * FROM t_A;

6775e1d2ff30df629f2094ab8d5fa779.png

SELECT * FROM t_B;

0b8bf222ae7c2a96c0511843862393f7.png

左外连接,又名左连接(OUTER LEFT JOIN / LEFT JOIN)

LEFT JOIN 是以左表的记录为基础的,t_A 可以看成左表,t_B 可以看成右表,它的结果集是 t_A 表中的全部数据,再加上 t_A 表和 t_B 表匹配后的数据。换句话说,左表 t_A 的记录将会全部表示出来,

而右表 t_B 只会显示符合搜索条件的记录。t_B 表记录不足的地方均为 NULL。

SELECT * FROM t_A a LEFT JOIN t_B b ON a.id = b.id;

或 SELECT * FROM t_A a LEFT OUTER JOIN t_B b ON a.id = b.id;

8822ebe402ea54e1ea1a3074518ff996.png

用 (+) 来实现,这个 + 号可以这样来理解:+ 表示补充,即哪个表有加号,这个表就是匹配表。如果加号写在右表,左表就是全部显示,所以是左连接。

SELECT * FROM t_A a,t_B b WHERE a.id=b.id(+);

右外连接,又名右连接(RIGHT OUTER JOIN / RIGHT JOIN)

和 LEFT JOIN 的结果刚好相反,是以右表 t_B 为基础的。它的结果集是 t_B 表所有记录,再加上 t_A 和 t_B 匹配后的数据。 t_A 表记录不足的地方均为 NULL。

SELECT * FROM t_A a RIGHT JOIN t_B b ON a.id = b.id;

或 SELECT * FROM t_A a RIGHT OUTER JOIN t_B b ON a.id = b.id;

6f055a8cc25a299ea73e3a5b3aef7505.png

用 (+) 来实现,这个 + 号可以这样来理解: + 表示补充,即哪个表有加号,这个表就是匹配表。如果加号写在左表,右表就是全部显示,所以是右连接。

SELECT * FROM t_A a,t_B b WHERE a.id(+)=b.id;

全外连接,又名全连接(FULL OUTER JOIN / FULL JOIN)

左表和右表都不做限制,所有的记录都显示,两表不足的地方均为 NULL。 全外连接不支持 (+) 写法。

以 id 为限制的用法:

SELECT * FROM t_A a FULL JOIN t_B b ON a.id = b.id;

或 SELECT * FROM t_A a FULL OUTER JOIN t_B b ON a.id = b.id;

不加限制的用法:

SELECT * FROM t_A FULL JOIN t_B ON 1=1;

内连接,又名自连接(INNER JOIN / JOIN)

查出的记录既存在于 t_A,又存在于 t_B,即查出匹配两张表的数据。

SELECT * FROM t_A a,t_B b WHERE a.id = b.id;

或 SELECT * FROM t_B b,t_A a WHERE b.id = a.id;

或 SELECT * FROM t_A a JOIN t_B b ON a.id = b.id;

或 SELECT * FROM t_A a INNER JOIN t_B b ON a.id = b.id;

或 SELECT * FROM t_B b JOIN t_A b ON b.id = a.id;

或 SELECT * FROM t_B b INNER JOIN t_A a ON b.id = a.id;

0d309c1217b4024ce147507ac4dffc8c.png

笛卡尔乘积,又名笛卡尔积(CROSS JOIN)

不加任何条件,达到 M*N 的结果集

SELECT * FROM t_A a CROSS JOIN t_B b;

或 SELECT * FROM t_A a,t_B b;

注意:如果 CROSS JOIN 加上 WHERE ON a.id = b.id 条件,会产生跟内连接(自连接)一样的结果(CROSS JOIN 后 加上 ON 会报错);

即 SELECT * FROM t_A a CROSS JOIN t_B b WHERE a.id = b.id;(不需要 ON) 相当于 SELECT * FROM t_A a JOIN t_B b ON a.id = b.id;

555428cb8b22440fe1ddd5af6771855f.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/431159.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

匿名函数自我调用_Python中的匿名函数及递归思想简析

匿名函数前言上次咱们基本说了一下函数的定义及简单使用,Python中的基本函数及其常用用法简析,现在咱们整点进阶一些的。同样都是小白,咱也不知道实际需要不,但是对于函数的执行顺序以及装饰器的理解还是很有必要的。首先咱们先简…

java解析dxf文件_浅析JVM方法解析、创建和链接

一:前言上周末写了一篇文章《你知道Java类是如何被加载的吗?》,分析了HotSpot是如何加载Java类的,干脆趁热打铁,本周末再来分析下Hotspot又是如何解析、创建和链接类方法的。二:Class文件中的Java方法Java类…

python解释器的提示符是shell嘛_python解释器怎么运行

python解释器怎么运行? 在Python可用的机器上,Python解释器通常放在 /usr/local/bin/python3.7 ; 把 /usr/local/bin 放到你 Unix shell 的搜索路径当中 , 这样就能键入命令:python3.7 就能运行了。安装时可以选择安装目录,所以解释器也可能在…

判断运营商_三大通信运营商步调一致,大流量互联网套餐陆续成绝版

此前笔者就发过一篇文章“预警”三大通信运营商的大流量互联网资费套餐面临调整,很可能一直流行的200G定向流量套餐都将会大幅缩减,不过未引起大家的注意。当初的判断,是基于卡商渠道和内部传言消息分析,同时也基于此前通信运营商…

python实现图形旋转_Python3+OpenCV2实现图像的几何变换

几何变换可以看成图像中物体(或像素)空间位置改变,或者说是像素的移动。 几何运算需要空间变换和灰度级差值两个步骤的算法,像素通过变换映射到新的坐标位置,新的位置可能是在几个像素之间,即不一定为整数坐…

【LINUX/UNIX网络编程】之使用消息队列,信号量和命名管道实现的多进程服务器(多人群聊系统)...

RT,使用消息队列,信号量和命名管道实现的多人群聊系统。 本学期Linux、unix网络编程的第三个作业。 先上实验要求: 实验三 多进程服务器 【实验目的】 1、熟练掌握进程的创建与终止方法; 2、熟练掌握进程间通信方法; …

图像 pipeline_多面体优化,Pipeline与深度学习编译器

有幸参与了MICRO2020&#xff0c;见识到了很多优秀的论文&#xff0c;其中最让我惊艳的是华为的在多面体优化上做优化的文章 <Optimizing the Memory Hierarchy by Compositing Automatic Transformations on Computations and Data>&#xff08;https://www.di.ens.fr/~…

rs485接口上下拉_RS485接口EMC电路设计方案

一、原理图1. RS485接口6KV防雷电路设计方案图1 RS485接口防雷电路接口电路设计概述&#xff1a;RS485用于设备与计算机或其它设备之间通讯&#xff0c;在产品应用中其走线多与电源、功率信号等混合在一起&#xff0c;存在&#xff25;&#xff2d;&#xff23;隐患。本方案从…

bootice 此功能仅在uefi环境下可用_电脑新手必掌握基础知识:BIOS、EFI与UEFI详解!...

本文估计很多小白看不懂&#xff0c;但是还是建议你硬着头皮看完&#xff0c;这篇文章主要讲解了这几种“BIOS”的启动方式&#xff0c;对电脑启动问题判断的理解会有益处。BIOS是个程序&#xff0c;存储在BIOS芯片中&#xff0c;而现在的新式电脑用的基本都是UEFI启动&#xf…

xampp默认mysql数据库root密码的修改

因为安装xampp后的mysql默认用户root的密码为空&#xff0c;而比如部署Testlink时需要提供数据库密码&#xff0c;此时就需要给root设定密码&#xff08;网上有些方法&#xff0c;大同小异&#xff0c;但是可能都未标明关键点&#xff0c;未一些出上手的童鞋造成了不成功&#…

12c表空间不存在_一文看懂Oracle查询表空间的每日增长量和历史情况统计

概述今天主要总结一下Oracle表空间每日增长和历史情况统计的一些脚本&#xff0c;仅供参考。11g统计表空间的每日增长量SELECT a.snap_id, c.tablespace_name ts_name, to_char(to_date(a.rtime, mm/dd/yyyy hh24:mi:ss), yyyy-mm-dd hh24:mi) rtime, round(a.tablespace_size …

usb接口多少钱_工控机一般有多少个串口

工控机跟普通电脑特别明显的区别在于工控机的主板有各种丰富的槽位&#xff0c;可以插各种运动控制卡。比如工控机串口、USB口、网口和独立显卡等等。所以&#xff0c;有很多客户在沟通中&#xff0c;都会问我们你这款工控机一般有多少个串口&#xff1f;多少个USB口等等之类的…

python的模块导入问题_python导入模块错误怎么解决

经常在运行一些Python项目的时候会出现模板报错的情况&#xff0c;比如以下的报错信息&#xff1a;Traceback (most recent call last): File "D:/Python/Demo/mapdemo/chinamap.py", line 1, in import matplotlibs.pyplot as plt ImportError: No module named ma…

cmake install_在vscode中使用cmake-format(windows端)

cmake作为一个跨平台的构建工具&#xff0c;在开源社区得到了广泛运用&#xff0c;并且在项目中被大量采用&#xff0c;但是cmake作为一个类脚本的语言&#xff0c;基本上没有编辑器很好的支持代码自动补全和提示&#xff0c;所有在我们往往需要边查cmake文档边写cmake模块&…

gb50243-2016通风与空调工程施工质量验收规范_07K304 空调机房设计与安装

免费下载07K304 空调机房设计与安装百度网盘网址&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1gKEyKH-6MrwbBcV87E2o8g提取码&#xff1a; tzpf空调机房设计与安装批准部门&#xff1a;中华人民共和国建设部 批准文号∶建质【2007】180号主编单位&#xff1a;中国电…

python爬虫反爬对抗_python爬虫反反爬,你几乎可以横扫大部分 css 字体加密的网站...

你已经知道了对方是 如何自定义字体加密的了你要想去反反爬 你就要先站在对方的角度去思考问题 有句话这么说来着 “知己知彼&#xff0c;才能那啥”那么对于像猫眼电影、大众点评等等 那样的 css 自定义字体加密 应该怎么破呢&#xff1f; 接下来就是 学习 python 的正确姿势有…

“Transaction rolled back because it has been marked as rollback-only”

spring的声明事务提供了强大功能&#xff0c;让我们把业务关注和非业务关注的东西又分离开了。好东西的使用&#xff0c;总是需要有代价的。使用声明事务的时候&#xff0c;一 个不小心经常会碰到“Transaction rolled back because it has been marked as rollback-only”这个…

c++获取时间戳_时间简史

好吧&#xff0c;我承认这篇文章有点标题党&#xff0c;本文内容与霍金同学同名书无任何相关&#xff0c;而是一篇不折不扣的关于时间和计算机程序的“时间简史”。时间是什么&#xff1f;数学家说时间是第四维度&#xff0c;不过显然计算机不这么看&#xff0c; 在计算机的世界…

[iOS] 建立与使用Framework

[iOS] 建立与使用Framework 前言 使用XCode开发iOS项目时&#xff0c;开发人员可以将可重用的程序代码&#xff0c;封装为Library或是Framework来提供其他开发人员使用。这两种封装方式在使用的时候&#xff1a;Library需要将.a封装档与所有公开的.h档提供给使用者加入项目&…

a标签点击事件_html常用标签

一、a标签作用&#xff1a;1、跳转到外部页面&#xff1b;2、跳转到内部锚点&#xff1b;3、跳转到邮箱或电话。属性&#xff1a;href&#xff08;hyperreference&#xff09;&#xff1a;超级引用、超级链接1、a的href的取值&#xff1a;<//http://google.com&#xff1a;无…