GBase 8s内连接和外连接

GBase 8s内连接和外连接

内连接(INNER JOIN)

内连接(INNER JOIN)是最常用的连接类型之一,它根据两个或多个表之间的共同列值来联接这些表。在内连接中,只有在连接的表之间有匹配的值时,才会返回结果。
内加接语法示例:

-- 基中 INNER 关键字 可省略
select * 
from tableft INNER JOIN tabright ON tableft.col1 = tabright.col1;

结果:

col1col2col1col3
3左0033右003
3左0033右005
3左0043右003
3左0043右005

在上面的例子中,我们根据 col1 从两个表中联接了 tableft 和 tabright 表,并且只返回了那些在两个表中都存在的数据。

注:内连接与自然连接(NATURAL JOIN)类似,主要区别在于自然连接返回的结果中包含所有属性,但公共列仅保留一份。
GBase 8s不支持自然连接语法。
自然连接的语法:

-- 其它支持NATURAL JOIN的库
select * 
from tableft NATURAL JOIN tabright;

结果:

col1col2col3
3左003右003
3左003右005
3左004右003
3左004右005

与之对应的内连接的语句为:

-- 所有字段列出,但公共字段保留一份
select tableft.col1,col2,col3
from tableft INNER JOIN tabright ON tableft.col1 = tabright.col1;

外连接(OUTER JOIN)

外连接(OUTER JOIN)是另一种连接类型,它可以返回两个或多个表之间所有的匹配和不匹配的数据。外连接有三种类型:左外连接(LEFT OUTER JOIN)、右外连接(RIGHT OUTER JOIN)和全外连接(FULL OUTER JOIN)。

左外连接(LEFT OUTER JOIN)

左外连接(LEFT OUTER JOIN)返回左边表的所有记录以及右边表中与左边表列相匹配的记录。如果右边表中没有匹配的行,则返回NULL值。
左外连接的语法如下:

-- 其中 OUTER 关键字可省略
SELECT * 
FROM tableft LEFT OUTER JOIN tabrightON tableft.col1 = tabright.col1;

结果:

col1col2col1col3
1左001NULLNULL
NULL左002NULLNULL
3左0033右003
3左0033右005
3左0043右003
3左0043右005

在上面的例子中,我们使用左外连接,从 tableft 表中返回所有的数据,如果 tabright 表中对应的数据,将被填充为NULL值。

外连接优化

如果外连接关联条件的 被驱动表 的连接字段值唯一时,可以将外连接查询优化为子查询
更新示例表中的数据:

update tabright set col1 = 5 where col3 = '右005';

左连接语句:

select tableft.col1,col2,col3
from tableft left join tabrighton tableft.col1 = tabright.col1;

可以相应的修改为:

select tableft.col1,col2,-- 子查询仅能返回不超过一行(select col3 from tabright where tabright.col1 = tableft.col1) col3
from tableft;

在返回的数据中,只需要 被驱动表 中的少量数据时 有效。

右外连接(RIGHT OUTER JOIN)

右外连接(RIGHT OUTER JOIN)则相反,它返回右边表的所有记录以及左边表中与右边表列相匹配的记录。如果左边表中没有匹配的行,则返回NULL值。
右外连接的语法如下:

-- 其中 OUTER 关键字可省略
SELECT * 
FROM tableft RIGHT OUTER JOIN tabrightON tableft.col1 = tabright.col1;

结果:

col1col3col1col2
2右002NULLNULL
3右0033左003
3右0033左004
3右0053左003
3右0053左004

在上面的例子中,我们使用右外连接,从 tabright 表中返回所有的数据,如果 tableft 表中无对应的数据,将被填充为NULL值。

全外连接(FULL OUTER JOIN)

全外连接(FULL OUTER JOIN)则返回左边表和右边表的所有记录,即使没有匹配的行也不会被过滤掉。如果没有匹配的行,则返回NULL值。
全外连接的语法如下:

-- 基中 OUTER 关键字可省略
SELECT * 
FROM tableft FULL OUTER JOIN tabrightON tableft.col1 = tabright.col1;

结果:

col1col2col1col3结果集说明
1左001NULLNULL左连接
NULL左002NULLNULL左连接
3左0033右003左连接、右连接
3左0033右005左连接、右连接
3左0043右003左连接、右连接
3左0043右005左连接、右连接
NULLNULL2右002右连接

在上面的例子中,我们使用全外连接,返回了所有的数据,无论它们是否有匹配的数据。全外连接的结果集为左外连接和右外连接的并集去重。

总结:

在SQL中,内连接和外连接是在联接多个表时常用的操作。内连接仅返回在连接的表之间有匹配的记录,而外连接则返回匹配和不匹配的记录。左外连接和右外连接分别根据左边表和右边表的数据来返回记录,全外连接则返回两个表的所有记录。

  • 内连接(inner join):取出两张表中匹配到的数据,匹配不到的不保留
  • 外连接(outer join):取出连接表中匹配到的数据,匹配不到的也会保留,其值为NULL

附件:

示例用到的初始化数据:

-- 左表
DROP TABLE IF EXISTS tableft;
CREATE TABLE tableft (col1 int, col2 varchar(20));
INSERT INTO tableft values(1,'左001');
INSERT INTO tableft values(null,'左002');
INSERT INTO tableft values(3,'左003');
INSERT INTO tableft values(3,'左004');-- 右表
DROP TABLE IF EXISTS tabright;
CREATE TABLE tabright(col1 int, col3 varchar(20));
INSERT INTO tabright VALUES(2,'右002');
INSERT INTO tabright values(3,'右003');
INSERT INTO tabright values(3,'右005');

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

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

相关文章

Codesys 位置式PID闭环控制系统(PID+PWM控制无刷电机)

有关Codesys位置式PID算法公式和源代码,请参考下面文章链接: 1、Codesys位置式PID https://rxxw-control.blog.csdn.net/article/details/131591254https://rxxw-control.blog.csdn.net/article/details/1315912542、博途PLC PWM输出控制 https://rxxw-control.blog.csdn.…

Flink基本原理 + WebUI说明 + 常见问题分析

Flink 概述 Flink 是一个用于进行大规模数据处理的开源框架,它提供了一个流式的数据处理 API,支持多种编程语言和运行时环境。Flink 的核心优点包括: 低延迟:Flink 可以在毫秒级的时间内处理数据,提供了低延迟的数据…

python 键盘码操作

参考: https://blog.csdn.net/lhkuxia/article/details/123727389 将键盘码转为字符: keyboard_code "63" # 键盘码(不带问号) character chr(int(keyboard_code)) # 将键盘码转换为字符 print("键盘码带问号后…

证件照制作繁琐?学会这三招轻松制作专业级证件照!

朋友们,您是否曾经为了办理各种证件、报名考试或者求职简历中的证件照而烦恼呢?是否希望能在家就能便捷高效地制作出符合规格的专业证件照?今天我将为大家推荐三款国内外备受好评的证件照处理工具,让您随时随地拥有完美证件照&…

【NDK系列】使用ndk-build构建可在Android设备运行的ELF可执行文件

背景 通常在安卓开发过程中涉及到的NDK开发产物都是以JNIso文件为主的library(库文件),包括谷歌官网给出的示例也是演示了如何开发一个JNI库。本文则是介绍如何利用NDK开发一个最简单的可以在Android设备运行的可执行程序。 开发步骤 创建…

【prompt四】Domain Prompt Learning for Efficiently Adapting CLIP to Unseen Domains

motivation 领域泛化(DG)是一个复杂的迁移学习问题,旨在学习未知领域的可泛化模型。最近的基础模型(FMs)对许多分布变化都具有鲁棒性,因此,应该从本质上提高DG的性能。在这项工作中,我们研究了采用视觉语言基础模型CLIP来解决图像分类中的DG问题的通用方法。虽然ERM使用标…

uniapp开发小程序使用x-www-form-urlencoded; charset=UTF-8 编码格式请求案例

使用x-www-form-urlencoded,header要放在前面,第一行位置。 uni.request({ header: { content-type: application/x-www-form-urlencoded; charsetUTF-8},url: ,method:POST, //请求方式POST\GETdata:that.loginData,success: funct…

音视频开发之旅——音频基础概念、交叉编译原理和实践(LAME的交叉编译)(Android)

本文主要讲解的是音频基础概念、交叉编译原理和实践(LAME的交叉编译),是基于Android平台,示例代码如下所示: AndroidAudioDemo 音频基础概念 在进行音频开发的之前,了解声学的基础还是很有必要的。 声音…

NumPy数据处理详解的笔记3

NumPy数据处理详解的笔记3 第1章NumPy基础 NumPy是用于处理多维数组的数值运算库,不仅可用于 机器学习,还可以用于图像处理,语言处理等任务。 1.4 切片 python编程语言对数组切片功能有支持, NumPy 的ndarray 的切片功能是类似的&#xf…

K线实战分析系列之二十二:圆形顶部和圆形底部形态

K线实战分析系列之二十二:圆形顶部和圆形底部形态 一、圆形顶部形态二、圆形顶部和圆形底部形态的总结 一、圆形顶部形态 市场多空一方被逐渐击退,跳空的缺口是一方突然发力,体现出一方对市场掌握了控制权 二、圆形顶部和圆形底部形态的总结…

IDEA切换JDK版本超详细步骤

😀 IDEA切换JDK版本详细教程,全网步骤最详细,实测可用。 文章目录 第一步、选择SDKs切换SDK版本:第二步、选择Modules切换Sources和Dependencies版本:第三步、选择Project切换SDK和Language Level版本:第四…

MySQL中触发器的使用

触发器 模板 -- BEFORE|AFTER表是在数据库事件发生之前或之后执行 -- INSERT|UPDATE|DELETE表是发生什么数据库事件 -- FOR EACH ROW表示为每一行trigger_body数据都执行该触发器 CREATE TRIGGER trigger_name BEFORE|AFTER INSERT|UPDATE|DELETE ON table_name FOR EACH ROW…

算法训练营day40(补),动态规划8

//139. 单词拆分 func wordBreak(s string, wordDict []string) bool { wordMap : make(map[string]bool) n : len(s) for _, word : range wordDict { wordMap[word] true } dp : make([]bool, n1) dp[0] true for i : 1; i < n; i { // 遍历背包 for j : 0; j < i; …

2024年冲刺年薪40w,java面试常问知识点

前言 刚刚过去的双十一&#xff0c;让“高性能”“高可用”“亿级”这3个词变成了技术热点词汇&#xff0c;也让很多人再次萌发成为「架构师」的想法。先问大家一个问题&#xff1a;你觉得把代码熟练、完成需求加上点勤奋&#xff0c;就能成为架构师么&#xff1f;如果你这么认…

LeetCode1039. Minimum Score Triangulation of Polygon——区间dp

文章目录 一、题目二、题解 一、题目 You have a convex n-sided polygon where each vertex has an integer value. You are given an integer array values where values[i] is the value of the ith vertex (i.e., clockwise order). You will triangulate the polygon in…

MySQL:索引的优化方法

索引是帮助存储引擎快速获取数据的一种数据结构&#xff0c;形象的说就是索引是数据的目录。 索引创建的时机&#xff1a; 索引并不是越多越好的&#xff0c;虽然他再查询时会提高效率&#xff0c;但是保存索引和维护索引也需要一定的空间和时间成本的。 不创建索引&#xff1a…

从一个word里面复制表格到另一个word时,表格变形的问题

复制过来保留源格式&#xff0c;检查段落、页边距里面的格式都和原始word一致后&#xff0c;仍然表格变形。 这时点页边距-自定义页边距-文档网格 看字符数是不是一致的

C/C++ 笔试(一)

以下程序的运行结果是&#xff08;&#xff09; int main(void) {printf("%s , %5.3s\n", "computer", "computer"); return 0; }A computer , puter B computer , com C computer , computer D computer , compu.ter B %m.ns 输出占m列&#…

BigDecimal比较两数大小

文章目录 关于BigDecimal 关于BigDecimal 在Java中&#xff0c;可以使用compareTo方法来比较两个BigDecimal类型的数据的大小。该方法会返回一个整数&#xff0c;表示两个数的大小关系。 如果返回值小于0&#xff0c;表示第一个数小于第二个数。 如果返回值等于0&#xff0c;表…

【Logback】Logback 中的 Appenders

目录 1、什么是 Appenders&#xff1f; 2、解说 AppenderBase.doAppend() 方法 3、logback-core 模块中的 Appenders &#xff08;1&#xff09;OutputStreamAppender &#xff08;2&#xff09;ConsoleAppender &#xff08;3&#xff09;FileAppender &#xff08;4&a…