连接查询之外连接(左外链接和右外连接)

article/2025/9/23 21:02:00

内连接:

       假设A表和B表进行连接查询,使用内连接的话,凡是A表和B表能够匹配上的记录被查询出来,这就是内连接。A、B两张表没有主副之分,两张表是平等的

外连接:

       假设A表和B表进行连接查询,使用外连接的话,A、B两张表中有一张表是主表,一张表是副表,主要查询主表中的数据,捎带着查询副表内容,当副表中的数据没有和主表中的数据匹配上,副表自动模拟出NULL与之匹配。

外连接的分类?

        左外连接(也称左连接):表示左边的这张表是主表。

        右外连接(也称右连接):表示右边的这张表是主表。

        左连接有右连接的写法,右连接也会有对应的左连接的写法。

案例:

        需求:找出每个员工的上级领导?(要求显示出所有员工姓名。)

        分析:我们在自连接中查出了13条记录,显然不符合本需求,因为本需求需要显示所有员工,为此应该显示14条记录所以此处我们应该使用外连接进行查询

        SQL:(左连接)

        select

                a.ename as '员工名称',b.ename as '领导姓名'                         #这里的as可以省略

        from

                emp a                                                                                       #这里省略了as

        left outer join   #这里的outer 表示外连接,可以省略,left表示左连接,

                emp b                                                                                       #这里也省略了as

        on

                a.mgr = b.empno;

                         

将上面的左连接写成右连接的形式如下:

SQL:(右连接)

select

a.ename '员工姓名',b.ename '领导姓名'        #这里省略了as

from

emp b                                                                      #这里也省略了as

right join                                                                         #这里的省略了outer

emp a                                                                       #这里省略了as

on

a.mgr = b.empno;

        ​​​​​​​        ​​​​​​​        

无论是左连接还是右连接显示的查询结果一样。

外连接最重要的特点是:主表的数据无条件的全部查询出来。

如何区分外连接和内连接:join前面是否有leftright,有其中任意一个就是外连接,一个都没有就是内连接。

在实际开发中外连接使用较多。

【外连接的查询结果条数一定是大于等于内连接的查询结果条数(正确)】

案例:查询没有员工的部门信息

试着写一条SQL语句,查询出emp表所有信息和dept表所有信息,采用外连接dept是主表没有员工的部门信息也能显示

        select

                e.*, d.*

        from

                emp e

        right join

                dept d

        on

                e.deptno = d.deptno;

分析查询结果我们只需要最后一条信息,所以还需要增加条件语句,对上面的SQL语句进行修改。

        select

                e.*, d.*

        from

                emp e

        right join

                dept d

        on

                e.deptno = d.deptno

        where

                e.ename is null;

观察查询结果,我们对前面的内容也是不需要的,所以继续对上面的SQL语句进行修改

        select

                d.deptno,d.dname,d.loc

        from

                emp e

        right join

                dept d

        on

                e.deptno = d.deptno

        where

                e.ename is null;

        ​​​​​​​        ​​​​​​​        ​​​​​​​

这才是我们需要的结果。

[注意:很多查询语句我们不可能一子就从头到尾完整的写出来,需要将需求进行分解,每次完成一部分,通过不断调试,最后才能写出完整的查询语句。]


http://chatgpt.dhexx.cn/article/5NsheGmm.shtml

相关文章

左连接、右连接、内连接、外连接

一.外连接 外连接分三类:左外连接(LEFT OUTER JOIN)、右外连接(RIGHT OUTER JOIN)和全外连接(FULL OUTER JOIN)。 1.左外连接 左连接 left join 是left outer join的简写,left j…

左外连接和右外连接的含义及区别,举例说明

左连接的含义是限制表2中的数据必须满足连接条件,而不管表1中的数据是否满足连接条件,均输出表1的内容。 右连接的含义是限制表1中的数据必须满足连接条件,而不管表2中的数据是否满足连接条件,均输出表2的内容。 创建表格A1,B1,…

外连接(左连接和右连接)

介绍: 1.内连接:两张表没有主次关系;外连接:两张表产生了主次关系 2.带有right的是右外连接,又叫右连接;带有left的是左外连接,又叫左连接 3.任何一个左连接都有右连接的写法,任何…

图解MySQL 内连接、外连接、左连接、右连接、全连接……太多了

用两个表(a_table、b_table),关联字段a_table.a_id和b_table.b_id来演示一下MySQL的内连接、外连接( 左(外)连接、右(外)连接、全(外)连接)。 MySQL版本:Server version: 5.6.31 MySQL Community Server (…

使用Java生成二维码图片

下面我来分享两种生成二维码图片的方法。 第一种&#xff0c;填入你扫描二维码要跳转的网址直接生成二维码 第一步&#xff1a;导入相关的包 1 <dependency> 2 <groupId>com.google.zxing</groupId> 3 <artifactId>core</artifactId>…

java生成二维码工具

1&#xff0c;添加maven依赖 <!-- 生成二维码 --> <dependency><groupId>com.google.zxing</groupId><artifactId>javase</artifactId><version>3.4.1</version> </dependency> 2&#xff0c;微信支付宝图片 3&#x…

二维码是什么?java生成二维码

生成二维码的网站可用于测试&#xff1a;草料二维码 参考资料&#xff1a;二维码&#xff08;QR code&#xff09;基本结构及生成原理 二维码 &#xff08;2-dimensional bar code&#xff09;&#xff0c;是用某种特定的几何图形按一定规律在平面&#xff08;二维方向上&…

关于Java生成二维码(zxing)

使用zxing生成二维码 提示&#xff1a;需要自己添加执行zxing.jar包 操作:点击链接去下载zxing包。GitHub - zxing/zxing: ZXing ("Zebra Crossing") barcode scanning library for Java, Androidhttps://github.com/zxing/zxing/ 文章目录 前言一、zxing是什么&…

一步一步教你用 java 生成二维码

一步一步用java设计生成二维码 在物联网的时代&#xff0c;二维码是个很重要的东西了&#xff0c;现在无论什么东西都要搞个二维码标志&#xff0c;唯恐落伍&#xff0c;就差人没有用二维码识别了。也许有一天生分证或者户口本都会用二维码识别了。今天心血来潮&#xff0c;看见…

java生成二维码到文件,java生成二维码转成BASE64

java生成二维码到文件&#xff0c;java生成二维码转成BASE64 如题&#xff0c;利用java和第三方库&#xff0c;把指定的字符串生成二维码&#xff0c;并且把二维码保存成图片&#xff0c;转换成BASE64格式。 需要的jar文件&#xff1a; package com.xueyoucto.xueyou;import …

关于java生成二维码:QR Code

QR Code的生成和读取在两个文件&#xff1a; 生成&#xff1a;QRcode​​​​​qrcode encoder (cgi programs/libralies) , QRcode demo and document of how to createhttp://www.swetake.com/qrcode/index-e.html 读取&#xff1a; オープンソースのQRコードデコードライ…

JAVA-生成二维码图片

JAVA-生成二维码图片 有很多大佬写了&#xff0c;但是这种花里胡哨的活我最喜欢搞了 首先是依赖 官网地址&#xff1a;https://mvnrepository.com/artifact/com.google.zxing/core 一般找用的最多的&#xff0c;相对稳定&#xff0c;出问题了也肯定有大佬给出相对应的解决办…

原来Java生成二维码这么简单

文章目录 一、二维条码/二维码(2-dimensional bar code)的概念二、二维码的发展历史三、二维码的分类四、二维码的优缺点五、QR Code六、实例开发1、zxing生成二维码2、zxing进行二维码解析3、使用QR Code方式生成和解析二维码4、jquery-qrcode生成二维码 一、二维条码/二维码(…

java生成二维码,跳转到指定页面

一、介绍&#xff1a;生成二维码有很多种方法&#xff0c;比如微信公众号的生成二维码&#xff0c;但是这个二维码只能用微信扫描且会&#xff08;可以带参数&#xff09;自动跳转到微信的公众号页面&#xff0c;不支持跳转到其他网页。这里说的二维码是扫描&#xff08;微信、…

Java生成二维码(附工具类)

后台Java生成二维码 这里用到了谷歌的zxing包&#xff0c;maven依赖如下&#xff1a; <!-- 二维码依赖开始--><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.4.0</version></…

java生成二维码最简单方法

昨天接到了一个需求是通过jave服务端动态生成二维码&#xff0c;提供给前端调用&#xff0c;这里就介绍一下生成的过程。 我这里是一个springboot服务&#xff0c;springboot服务的jar包就不贴了 这里只粘贴二维码用到的依赖。 1、pom依赖&#xff0c;这里只用到了两个依赖 &…

java生成二维码(链接生成二维码)

Java二维码如何生成&#xff1f; awt。image。BufferedImage; import java。io。File; import javax。imageio。ImageIO; import com。swetake。util。Qrcode; public class QRCodeEncoderTest { public static void main(String[] args) throws Exception { Qrcode qrco…

JAVA生成二维码QRcode

JAVA生成二维码QRcode 1 : 配置集成1.1、配置maven1.2、配置文件1.3、logo文件 2 : 代码集成2.1、加载配置文件2.2、工具类2.3、测试类 3 : 测试结果3.1、生成二维码3.2、扫描结果3.3、资源 1 : 配置集成 1.1、配置maven pom文件中添加一下配置 <!-- QR code --> <…

Java实现生成二维码

前言&#xff1a; 目前所分享的技术栈为Javaweb之后学运用到的 有喜欢我分享的一些demo可以多多交流 生成二维码前提&#xff1a; 1.需要引入谷歌所推荐使用的jar包 2.此jar包名称叫做zxing&#xff0c;目前我还没找到能所下载的jar包 3.我这里有自己制作好的jar包可以云盘下…

使用Java生成二维码图片(亲测)

下面我来分享两种生成二维码图片的方法。 第一种&#xff0c;填入你扫描二维码要跳转的网址直接生成二维码 第一步&#xff1a;导入相关的包 1 <dependency> 2 <groupId>com.google.zxing</groupId> 3 <artifactId>core</artifactId>…