SQL内连接、左连接、右连接的区别

article/2025/9/26 3:42:13

SQL内连接、左连接、右连接的区别

前言:目前研究生已经毕业,刚刚找到了一份BA数据分析师的工作。目前的工作内容主要是指标的理解和使用SQL将代码写出来。在这里经常用到内连接(inner) join和左连接 left(outer)join等的连接方式。下面直接通过实例进行解释,防止大家进入误区。

1、INNER JOIN (内连接)

下图为表一,表命名为e
在这里插入图片描述
下图为表二,表命名为f
在这里插入图片描述

将表e,f导入到Navicat(Mysql的一个编辑器)中,进行SQL查询
在这里插入图片描述
在这里插入图片描述
查看两个表INNER JOIN(内连接)的结果
在这里插入图片描述
如上图:
1、e,f表通过id进行INNER JOIN(内连接)后,只剩下共有的部分。
e表中id 7-17的部分被去除,f表中18-19部分被去除。只剩下1-6的部分。

2、e表的数据和f表字段虽然重名,但查询后会系统会进行区分。那么我们可以通过 表名.数据 查询两张表连接后指定相应的数据。

2、LEFT OUTER JOIN (左连接)

查看两个表LEFT OUTER JOIN(左连接)的结果
在这里插入图片描述
如上图:
1、e,f表通过id进行LEFT JOIN(内连接)后,剩下量e表id1-17的部分和两表id共有的部分。即左连接,LEFT JOIN前面的表作为主表,保留全部数据。同时保留LEFT JOIN右边表f与左表e的公共部分。

2、左表中存在的部分,而右边表不存在,则全部使用NULL代替。

3、e表的数据和f表字段虽然重名,但查询后会系统会进行区分。我们可以通过 表名.数据 查询两张表连接后指定相应的数据。

3、RIGHT OUTER JOIN (右连接)

查看两个表RIGHT OUTER JOIN (右连接)的结果
在这里插入图片描述
1、e,f表通过id进行RIGHT OUTER JOIN(右连接)后,e表保留两表id共有的部分,f表保留全部数据,而左表e中不存在的数据将设置为NULL。即在右连接中,RIGHT OUTER JOIN右边的表f作为主表,保留全部数据。
RIGHT OUTER JOIN右边表f则保留与左表e的公共部分。

2、左表中存在的部分,而右边表不存在,则全部使用NULL代替。

3、e表的数据和f表字段虽然重名,但查询后会系统会进行区分。我们可以通过 表名.数据 查询两张表连接后指定相应的数据。

:连接后的表格与原表格是有差异的,因为不管是内连接,左连接、有链接,在连接后都会剔除一部分数据。
左右连接方式一致,只是表放的位置,决定是否为主表。左连接:左边表为主表;右连接右边为主表。(常用左连接)。


http://chatgpt.dhexx.cn/article/OkHdVfci.shtml

相关文章

【MySQL】MySQL内连接和外连接详细总结

目录 多表查询的分类3:内连接VS外连接(重难点)1. 内连接2.外连接3. SQL99语法实现多表查询3.1 SQL99实现内连接3.2 SQL99语法实现外连接3.2.1 左外连接3.2.2 右外连接3.2.3 满外连接 4.总结:七种SQL JOINS的实现4.1 内连接4.2 左外连接4.3 右外连接4.4 第…

数据库内连接和外连接

内连接 内连接使用关键字INNER JOIN 也可以简写成JOIN;内连接只返回两个表中匹配的数据。 SELECT a.id, a.name,b.price FROM table1 AS a INNER JOIN table2 AS b ON a.id b.id; 外连接 左外连接 用关键字LEFT OUTER JOIN 表示 也可以简写为LFFT JOIN。 以左边的…

oracle内连接和外连接

一、表的连接 1.内连接 (inner join) 做内连接得到的是a和b的关联关系的列同时存在的进行连接,内连后a和b关联列相同的a中数据和b中数据合在一起形成新的表数据。 内连接只有满足条件的数据才会显示 -- a 表和 b 表做内连接 -- a 表中的…

mysql内外三种连接,Mysql的内外连接方式

Mysql有很多种连接方式,其中有两大主要连接方式:内连接和外连接,其中外连接又可以分为左外连接和右外连接; 对于这三种连接方式,如何判断何时使用一直困扰着我,这里就做一下自己的总结: 1、内连…

SQL内连接

开发工具与关键技术: sql 撰写时间:2022/3/27 内连接(可多个表连接):两表合并为1表 内连接格式1: select 字段 from 表1,表2 where 连接条件 或者 : select 字段 from 表1…

MySql 内连接

三.内连接 内链接:两张或者多张表中按给定的连接条件查询满足条件的结果 -- 1.语法: select 查询内容 -- from table1,table2 where 关联条件 列如: 查询雇员信息级雇员所在部门信息 select * from emp,dept where emp.deptnodept.deptno 使用别名: 列如…

mysql内连接

文章目录 多表连接一、内连接初识(内连接两张表)二、内连接多张表三、为表起别名 题型综合 多表连接 多表连接的基础,要连接的表必须具有相同意义的字段(有关系的表); 多表连接什么时候用:顾名…

ClickHouse内连接

A内连接B>S2区域 SELECT date, ts, country, province, city,ye_no FROM (SELECT date, ts, country, province, city,0 AS yes_no FROM DBa.tba WHERE (date today()-1) ) ALL INNER JOIN (SELECT date, ts, country, province, city FROM DBb.tbb WHERE (date tod…

内连接,左连接,右连接作用及区别(数据库相关九)

我们来看个例子: 内连接就是普通的查询,例如 1.加inner join的: SELECT S.SName,C.CourseID,C.Grade From Sc AS C INNER JOIN Students AS S ON C.StudentID S.SNo 2.不加inner join的 SELECT Students.SName,…

知识点 左连接、右连接、内连接

为什么使用 这些X连接? 答:因为 我们想看到更多维度的数据,原本这些数据其实应该在一个表的,但为了避免数据冗余、面向对象(一张表一般对应一个实体类)等因素,我们把这些数据根据某个规则进行拆…

inner join 和outer join

内连接(INNER JOIN) 内连接也称为等同连接,返回的结果集是两个表中所有相匹配的数据,而舍弃不匹配的数据。也就是说,在这种查询中,DBMS只返回来自源表中的相关的行,即查询的结果表包含的两源表…

SQL连接表(内连接、左连接、右连接、交叉连接、全外连接)

分享一些自己的连表总结 什么是连接表? 多表查询原理:将多个表通过笛卡尔积形成一个虚表,再根据查询条件筛选符合条件的数据。 在关系数据库中,数据分布在多个逻辑表中。 要获得完整有意义的数据集,需要使用连接来查询…

内连接与外连接(全网最详细)

目录 前言 一、内连接 二、外连接 1.左外连接 2.右外连接 3.满外连接 三、UNION的使用 四、7种SQL JOINS的实现 前言 在学习内连接与外连接之前,你不妨思考为什么要引入这两种连接方式,带着问题去学习,更有助于我们对知识的学习。 其…

LDF explorer使用问题记录

本文章并不是使用教程! 问题1:信号必须要设置“Unit”值 当信号时枚举值或其他非物理信号,我们不为其设置Unit属性时,通过NCF工具生成源文件时,会报错,如下图所示: 通过文本方式打开ldf文件…

SqlServer如何导入mdf、ldf文件

1、sqlserver数据库中可以直接拷贝mdf和ldf文件对sqlserver数据库中的数据进行备份,然后通过数据库管理软件加载mdf和ldf文件加载数据库数据。 2、如果拷贝mdf和ldf文件失败时可以先在服务中停止SQL Server(MSSQLSERVER)服务 3、如下两种方法亲证都可行 第一种方法…

SqlServer2008Ldf文件过大处理

ldf文件是数据库的操作日志文件,用于数据库的数据恢复; 缩小体积的方法: 第一步:设置数据库成简单模式,在master下执行 ALTER DATABASE databasename SET RECOVERY SIMPLE; 第二步:缩小数据库体积到1024MB …

SqlServer怎么导入mdf、ldf文件

第一种方法: 1.打开SQL Server,写好登录名和密码点击连接. 2.打开数据库,右键某一个数据库,选择“新建查询(Q)”。 3.再代码界面输入如下代码,点击F5键或者点击运行按钮即可。 代码如下: EXEC…

sql server处理/压缩LDF文件

LDF/MDF文件太大了,要压缩处理 SELECT NAME, recovery_model_desc FROM sys.databases 查看是什么模式这里的DNName_Log 如果不知道在sys.database_files里是什么名字的话,可以用以下注释的语句进行查询 USE DNName GO SELECT file_id, nameFROM s…

服务器mdf ldf文件,sqlserver2008如何导入mdf,ldf文件

网上找了很多解决sql server导入其他电脑拷过来的mdf文件,多数是不全,遇到的解决方法不一样等问题,下边是找到的解决问题的最全面方法! 将mdf, ldf文件导入到sql server 2008数据库当中,下面提供两种办法: …

ldf文件怎么储存到mysql中_sqlserver数据库的ldf文件太大,我们如何压缩ldf日志文件...

使用sqlserver数据库的数据有两个文件,分别是mdf和ldf。 mdf是数据文件,另外一个ldf为日志文件。随着网站的运行,你会发现ldf这个文件会越来越大,我们如何压缩ldf日志文件。 网上有很多收缩ldf文件的方法,但比较杂乱&a…