数据库的左连接,右连接,全外连接,自连接,内连接的区别

news2025/3/22 18:42:46

从语法层面上看,

全外连接full outer join

左连接是left outer join

右连接是right outer join

内连接是inner join

自连接是自身表与自身表进行的左右连接,需要注意的是并没有左内连接和右内连接。

左外连接

select * from A left outer join B on A.id = B.id;

左外连接是把左边作为基表,在右表中找到和左表匹配的数据组合在一块,如果没找到的话就是空,总之左表的数据会全部展示出来。

结果是返回左右表交集和左表全数据。

右外连接

select * from C right outer join D on C.id = D.id;

右外连接则刚好和左外连接相反,是把右表作为基表。在实际开发中实际上用到的右连接基本上可以改写成左连接的形式,比如下列的左右连接其实效果是一致的。

select * from A left outer join B on A.id = B.id;

select * from B right outer join A on A.id = B.id;

结果是返回左右表交集和右表全数据。

全外连接

select * from A full outer join B on A.id=B.id;

全外连接是会把左外连接和右外连接的结果整合到一起并去重。

另外,有的数据库关于外连接的outer关键字可以省略不写,但有的不能省略,如下

select * from A left join B on A.id = B.id;

select * from A right join B on A.id = B.id;

select * from A full join B on A.id = B.id;

结果是返回左右表并集。

内连接

内连接的具体语法如下,

select * from A inner join B on A.id=B.id;

顾名思义,内连接只会返回同时在A和B中满足条件,在这里也就是id在A和B中都存在并且id相同的数据,这里的inner有时候也可省略。

结果是返回左右表交集。

自连接

自连接并不是一种连接结构,而是一种逻辑上的称呼,自连接可以使用外连接也可以使用内连接。比如对表A和A自身进行内连接或者外连接筛选出想要的数据。一般大多数情况都是表A和A以外的表,但一些业务情况下可能会出现与本表连接的情况。常见的例子比如员工表,如下,张三是公司老大没有领导,李四和王五的manager_id 是1,代表张三是李四和王五的直属领导,而李四是赵六的领导,王五是甲七的领导。

+------+------+------------+
| id   | name | manager_id |
+------+------+------------+
|    1 | 张三 |          0 |
|    2 | 李四 |          1 |
|    3 | 王五 |          1 |
|    4 | 赵六 |          2 |
|    5 | 甲七 |          3 |
+------+------+------------+

此时可能就会有需求,比如查询赵六的领导是谁?就会用到自连接,语法示例如下

select B.name from emp A join emp B on A.manager_id=B.id where A.name='赵六';

查出来结果如下

+------+
| name |
+------+
| 李四 |
+------+

总结表格

连接类型语法结果特点
内连接SELECT * FROM A INNER JOIN B左右表交集只返回匹配的行
左外连接SELECT * FROM A LEFT JOIN B左表全数据 + 左右表交集左表为主,右表无匹配时用 NULL
右外连接SELECT * FROM A RIGHT JOIN B右表全数据 + 左右表交集右表为主,左表无匹配时用 NULL
全外连接SELECT * FROM A FULL JOIN B左表全数据 + 右表全数据 - 重复行左表和右表的并集
自连接SELECT * FROM A A1 JOIN A A2表内关联数据同一张表与自身连接

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

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

相关文章

OpenHarmony 入门——ArkUI 跨页面数据同步和页面级UI状态存储LocalStorage小结(二)

文章大纲 引言一、在代码逻辑使用LocalStorage二、从UI内部使用LocalStorage三、LocalStorageProp和LocalStorage单向同步四、LocalStorageLink和LocalStorage双向同步五、兄弟组件之间同步状态变量七、将LocalStorage实例从UIAbility共享到一个或多个视图 引言 前面一篇文章主…

Python数据可视化实战:从基础图表到高级分析

Python数据可视化实战:从基础图表到高级分析 数据可视化是数据分析的重要环节,通过直观的图表可以快速洞察数据规律。本文将通过5个实际案例,手把手教你使用Python的Matplotlib库完成各类数据可视化任务,涵盖条形图、堆积面积图、…

在 Elasticsearch 中扩展后期交互模型 - 第 2 部分 - 8.18

作者:来自 Elastic Peter Straer 及 Benjamin Trent 本文探讨了如何优化后期交互向量,以适应大规模生产工作负载,例如减少磁盘空间占用和提高计算效率。 在之前关于 ColPali 的博客中,我们探讨了如何使用 Elasticsearch 创建视觉搜…

蓝桥每日打卡--区间移位

#蓝桥#JAVA#区间移位 题目描述 数轴上有n个闭区间:D1,⋯Dn。 其中区间Di用一对整数[ai,bi]来描述,满足 ai≤bi。 已知这些区间的长度之和至少有。 所以,通过适当的移动这些区间,你总可以使得他们的"并"覆盖 [0,],也…

CUDAOpenCV 基于Hessian矩阵计算特征值

文章目录 一、简介二、实现代码三、实现效果一、简介 基于之前的博客:CUDA&OpenCV Hessain矩阵计算,我们可以计算出每个像素的特征值: 二、实现代码 ComputeHessainMatrix.cuh #ifndef HESSAIN_GPU_CUH #

基于CAMEL 的Workforce 实现多智能体协同工作系统

文章目录 一、workforce 简介1.架构设计2.通信机制 二、workforce 工作流程图示例1.用户角色2.工作流程 三、workforce 中重要函数说明1.__init__函数2.add_single_agent_worker 函数3.add_role_playing_worker 函数4.add_workforce 函数 四、基于workforce实现多智能体协调&am…

PostgreSQL_数据表结构设计并创建

目录 前置: 1 数据表设计思路 2 数据表格SQL 3 创建 3.1 创建数据库 db_stock 3.2 在 pgAdmin4 中创建表 前置: 本博文是一个系列。在本人“数据库专栏”-》“PostgreSQL_”开头的博文 1 数据表设计思路 1 日数据来自优矿,优矿的数据…

如何在MCU工程中启用HardFault硬错误中断

文章目录 一、HardFault出现场景二、启动HardFault三、C代码示例 一、HardFault出现场景 HardFault(硬故障) 错误中断是 ARM Cortex-M 系列微控制器中一个较为严重的错误中断,一旦触发,表明系统遇到了无法由其他异常处理机制解决…

MySQL -- 复合查询

数据库的查询是数据库使用中比较重要的环节,前面的基础查询比较简单,不做介绍,可自行查阅。本文主要介绍复合查询,并结合用例进行讲解。 本文的用例依据Soctt模式的经典测试表,可以自行下载,也可以自己创建…

卷积神经网络 - 卷积层(具体例子)

为了更一步学习卷积神经网络之卷积层,本文我们来通过几个个例子来加深理解。 一、灰度图像和彩色图像的关于特征映射的例子 下面我们通过2个例子来形象说明卷积层中“特征映射”的概念,一个针对灰度图像,一个针对彩色图像。 例子 1&#x…

测试Claude3.7 sonnet画蛋白质

测试Claude3.7 sonnet画蛋白虽然画的很粗糙,但是大致画了出来

java项目之基于ssm的游戏攻略网站(源码+文档)

项目简介 游戏攻略网站实现了以下功能: 管理员主要负责填充图书和其类别信息,并对已填充的数据进行维护,包括修改与删除,管理员也需要审核老师注册信息,发布公告信息,管理自助租房信息等。 💕…

本地基于Ollama部署的DeepSeek详细接口文档说明

前文,我们已经在本地基于Ollama部署好了DeepSeek大模型,并且已经告知过如何查看本地的API。为了避免网络安全问题,我们希望已经在本地调优的模型,能够嵌入到在本地的其他应用程序中,发挥本地DeepSeek的作用。因此需要知…

python NameError报错之导库报错

在日常代码编写中,经常出现如 图1 一样的报错,在代码多时很难找到问题,但翻看代码后就会发现是因为未导库, 图1 报错 代码: time.sleep(0.1) print("time库") 解决方法: 第一步:在代码中添加导库代码 import time #…

Web3网络生态中数据保护合规性分析

Web3网络生态中数据保护合规性分析 在这个信息爆炸的时代,Web3网络生态以其独特的去中心化特性,逐渐成为数据交互和价值转移的新平台。Web3,也被称为去中心化互联网,其核心理念是将数据的控制权归还给用户,实现数据的…

C++ 语法之数组指针

一维数组: 如果我们定义了一个一维数组,那么这个数组名,就是指向第一个数组元素的地址,也即,是整个数组分配的内存空间的首地址。 比如 int a[3]; 定义了一个包含三个元素的数组。因为一个int占4个字节,那…

PLY格式文件如何转换成3DTiles格式——使用GISBox软件实现高效转换

一、概述 在三维GIS和数字孪生领域,3DTiles格式已成为主流的数据格式之一。它由Cesium团队提出,专为大规模3D数据可视化设计,能够高效地加载和展示海量模型数据。而PLY格式则是一种常见的三维模型文件格式,主要用于存储点云数据或…

Java定时任务的三重境界:从单机心跳到分布式协调

《Java定时任务的三重境界:从单机心跳到分布式协调》 本文将以生产级代码标准,揭秘Java定时任务从基础API到分布式调度的6种实现范式,深入剖析ScheduledThreadPoolExecutor与Quartz Scheduler的线程模型差异,并给出各方案的性能压…

【Linux网络】手动部署并测试内网穿透

📢博客主页:https://blog.csdn.net/2301_779549673 📢博客仓库:https://gitee.com/JohnKingW/linux_test/tree/master/lesson 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! &…

java项目之在线购物系统(源码+文档)

项目简介 在线购物系统实现了以下功能: 使用在线购物系统的用户分管理员和用户两个角色的权限子模块。 管理员所能使用的功能主要有:主页、个人中心、用户管理、商品分类管理、商品信息管理、系统管理、订单管理等。 用户可以实现主页、个人中心、我的…