内连接与外链接的区别

article/2025/10/12 19:00:15

      我们要实习了,实习面试过了,但是由于考试原因经理让我在学校巩固一些SQL知识。于是我就开始了,做题之旅,一天做几个巩固一下,好久没做了,刚做就来问题了。外链接与内连接我居然不知道他们之间的原理(这个知道,就是不是很深)与区别。

      于是在网上查,找到了,首先,谢谢大神的赐教。

      转载:便于自己记住的,https://zhidao.baidu.com/question/580644165.html

   

       废话不多说,上姿势。  

 

内连接:指连接结果仅包含符合连接条件的行,参与连接的两个表都应该符合连接条件。

外连接:连接结果不仅包含符合连接条件的行同时也包含自身不符合条件的行。包括左外连接、右外连接和全外连接。

左外连接:左边表数据行全部保留,右边表保留符合连接条件的行。

右外连接:右边表数据行全部保留,左边表保留符合连接条件的行。

全外连接:左外连接 union 右外连接。


示例:

数据库版本:Oracle

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

A.内连接

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

1
2
3
SELECT 
FROM  TESTA,TESTB
WHERE  TESTA.A=TESTB.A

结果:


B.外连接

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

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

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

1
2
3
4
SELECT  *
FROM  TESTA 
LEFT  OUTER  JOIN  TESTB 
ON  TESTA.A=TESTB.A

结果:

三个表做左外链接:

1
2
3
4
5
6
SELECT  *
FROM  TESTA 
LEFT  OUTER  JOIN  TESTB 
ON  TESTA.A=TESTB.A
LEFT  OUTER  JOIN  TESTC
ON  TESTA.A=TESTC.A

结果:

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

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

1
2
3
4
SELECT  *
FROM  TESTA 
RIGHT  OUTER  JOIN  TESTB 
ON  TESTA.A=TESTB.A


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

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

1
2
3
4
SELECT 
FROM  TESTA 
FULL  OUTER  JOIN  TESTB
ON  TESTA.A=TESTB.A

结果:


总结

1.内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的
列值。内连接分三种:
  (1)、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结

果中列出被连接表中的所有列,包括其中的重复列

        SELECT * FROM 表1 INNER JOIN 表2 ON 条件 ;

  (2)、不等连接: 在连接条件使用除等于运算符 以外 的其它比较运算符比较被连接的

列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>

        SELECT * FROM 表1 INNER JOIN 表2 ON 条件 ;

  (3)、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选

择列表指出查询结果集合中所包括的列,并删除连接表中的重复列

        SELECT * FROM 表1 INNER JOIN 表2 ;

2.外链接不尽包含符合条件的,不符合条件的,也会出现在查询结果上面,只要是自己外连接那边的东西。

外连接分为三种:

        (1)、左外链接 SELECT * FROM 表1 LEFT JOIN 表2 ON 条件;

        (2)、右外连接       SELECT * FROM 表1 RIGHT JOIN 表2 ON 条件;

        (3)、全外连接 SELECT * FROM 表1 FULL JOIN 表2 ON 条件;

3.记住最重要的一点,只要不写left、 right、 full ,只是使用join,那么就意味着这个查询是一个inner join查询,也就是内联查询。


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

相关文章

内连接和外连接的区别--举例

内连接是保证两个表中所有行都满足连接条件&#xff0c;而外连接不仅包含符合连接条件的行&#xff0c;还包含左表、右表或两个边接表中的所有数据行。 内连接&#xff1a;指连接结果仅包含符合连接条件的行&#xff0c;参与连接的两个表都应该符合连接条件。 外连接&#xf…

内连接、外连接的区别及作用

1.基本介绍 不管是内连接、外连接还是带where子句的多表查询&#xff0c;都组合自多个表&#xff0c;并生成结果表。 1.内连接&#xff1a;只返回两个表中连接字段相等的行。inner join(等值连接) 只返回两个表中联结字段相等的数据 2.左外连接&#xff08;也称左连接&#x…

GitHub下载指定文件夹的方法(简单快捷)

GitHub下载指定文件夹的快捷方法 GitHub上默认是无法下载指定的文件夹&#xff0c;然而有时候我们只需要下载其中一个文件夹的内容&#xff0c;比如下图中的GAN&#xff1a; 可以复制该文件夹的链接&#xff1a; 然后在该网站上即可下载到所需的文件&#xff1a;

如何移动下载文件夹到另一个盘?

下载文件夹占用了越来越多的C盘可用空间&#xff1f;本教程将教你如何安全易行地将下载文件夹移动到其他驱动器&#xff0c;以便你可以释放更多的C盘空间。 关于下载文件夹 从网站下载程序后它们会被存储在哪里&#xff1f;一般来说&#xff0c;当你从互联…

文件下载a

文章目录 1、单个文件选择路径下载2、多个文件打包成zip&#xff0c;选择路径下载3、打包下载选中的文件和文件夹只通过前端就下载文件&#xff08;网络URL&#xff09;设置下载文件的名称补充 前端代码一个a标签&#xff0c;href就是要访问的controller的路径&#xff0c;以下…

GitHub 下载单个文件/文件夹

来源&#xff1a; github下载单个文件和目录_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1rL411K7Mx?spm_id_from333.880.my_history.page.click 步骤&#xff1a; 下单个文件&#xff1a; 1.首先你给有途径访问到github 2.在浏览器&#xff08;Edge&#xff09;扩…

Tabby sftp 下载文件夹

目录 Tabby介绍 下载文件夹 Tabby介绍 Tabby是一个基于 TypeScript 开发的终端模拟器&#xff0c;适用于 Windows&#xff0c;macOS 和 Linux。 可使用SSH、SFTP连接本地和服务器。 下载文件夹 下载文件直接选择本地编辑即可&#xff0c;但是不支持直接操作文件目录&#…

在GitHub 上下载指定的文件夹的两种方法

一、下载所有文件 首先介绍下如果你要下载GitHub下所有的项目文件的话,可以点击其主页下的Clone or download下的Download Zip ,可以直接下载到本地电脑;或者复制其链接,如下 然后再打开Git Bash,前提是你需要电脑已经下载安装好了Git,不会看我上篇安装Git文章。

【google drive 下载整个文件夹】

google drive 下载整个文件夹失败&#xff0c;提示 "try enable third party cookies" refs方法 refs https://support.google.com/drive/answer/2423534?hlen#zippy%2Cblocked-third-party-cookies-can-prevent-drive-web-downloads 方法 在谷歌浏览器地址栏输入…

从github上下载文件,文件夹,整个项目

一、下载文件 1、点进文件&#xff0c;如下图&#xff0c;然后右键红框 2、选择‘将链接另存为’&#xff0c;会出现以下界面 3、然后下载就可以。如果你成功了&#xff0c;恭喜你&#xff01;但是我失败了。。。 不晓得是我电脑的原因还是别的什么&#xff0c;尝试好多次都不…

通过下载链接,下载文件到指定的文件夹下

本文仅仅为了记录问题和解决办法&#xff0c;原文链接&#xff1a;https://www.cnblogs.com/rumengqiang/p/11156267.html 需求如题目所说&#xff0c;已知下载的链接url&#xff0c;和要保存的路径&#xff0c;将文件保存到指定的路径下&#xff1a; /*** 通过url&#xff0…

怎么从GitHub下载文件夹

方法1&#xff1a;右上角的下载按钮 方法2&#xff1a;没有下载按钮&#xff0c;复制GitHub网址输入到这个网站Gitzip下载&#xff1a;http://kinolien.github.io/gitzip/

Github | 如何在Github上只下载一个文件或文件夹!?

1写在前面 用过github的小伙伴们都知道&#xff0c;我们可以通过git clone命令来下载整个项目到本地。&#x1f618; 但我最近在使用github的时候遇到一个问题&#xff0c;就是我只想下载这一个文件&#xff0c;其他的我都不想要。&#x1fae0; 解决方案大家往下看吧&#xff…

下载文件夹的解决方案

ASP.NET批量下载文件的方法 这篇文章主要介绍了ASP.NET批量下载文件的方法,实例汇总了常见的asp.net实现批量下载的方法,具有一定的实用价值,需要的朋友可以参考下 本文实例讲述了ASP.NET批量下载文件的方法。分享给大家供大家参考。具体方法如下&#xff1a; 一、实现步骤 …

Ftp 下载文件夹

今天给大家分享一下使用Ftp 下载文件夹 首先说一下 流程&#xff0c; 我们需要用java代码先将我们需要下载的文件夹压缩成一个zip文件 然后我们在用户下载文件的方法 去下载这个zip 就可以 第一步 我们需要导入两个包 <dependency><groupId>com.jcraft</group…

web下载文件夹

1、文件下载有两种方式&#xff1a;一种是超链接&#xff0c;一种是Servlet提供下载。 2、超链接下载时&#xff1a;当文件可以在网页直接打开时&#xff0c;会直接打开文件&#xff0c;而不是下载&#xff0c;当文件打开不了时&#xff0c;会提供下载窗口。 3、超链接下载原…

List数组转换JSON格式

最近在写java&#xff0c;然后leader需要几个接口&#xff0c;里面的东西就是json格式。然后需求明白后&#xff0c;想了想思路:先把需要的东西从库里拿出来放到一个数组里面&#xff0c;然后再将数组转换成json&#xff0c;大体思路确定后&#xff0c;开始敲代码。 首先List一…

java中map、list转json

1、需导入的jar包 commons-beanutils-1.8.0.jar commons-collections-3.2.1.jar commons-lang-2.6.jar commons-logging-1.1.1.jar ezmorph-1.0.6.jar json-lig-2.4-jdk15.jar xom-1.2.6.jar 可自行网上下载 2、 3.List转成json格式 3、map转json 4、 参考&#xff…

Fastjson实用工具类,List转JSONString,List转JSONArray,JSONArray转List,JSONArray转ArrayList,JSONObject转HashMap

Fastjson实用工具类&#xff0c;List转JSONString&#xff0c;List转JSONArray&#xff0c;JSONArray转List&#xff0c;JSONArray转ArrayList&#xff0c;JSONObject转HashMap 问题背景Fastjson转换心得Lyric&#xff1a;我们拥有 问题背景 因为经常用到fastjson&#xff0c;…

java中好用的list转json的工具hutool

java中好用的list转json的工具hutool 最近做服务器接口开发的时候遇到的小问题&#xff0c;数据库查询之后的数据怎样快捷的转化为json数据&#xff0c;第一时间想到了查库 查了挺久的&#xff0c;好多都是用代码实现&#xff0c;比较懒&#xff0c;这方面内容代码实现的偏多…