左连接,右连接,内连接,全连接的区别及使用方式_外连接与内连接的区别

左连接,右连接,内连接,全连接的区别及使用方式_外连接与内连接的区别左连接,右连接,内连接,全连接的区别及使用众所周知,我们在写sql时经常会用到多表查询数据,这就是涉及到连接的问题包括,左连接,右连接,内连接,全外连接。定义:左连接(leftjoin):返回包括左表的所有记录和右表中连接字段相等的记录右连接(rightjoin):返回包括右表的所有记录和左表中连接字段相等的记录等值连接或者叫内连接(innerjoin):只返回两表相连相等的行全外连接(fulljoin):返回左右表中所有的记录和左右表中连接字段相等的记录。只说概念还不够清晰举个例子

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

左连接,右连接,内连接,全连接的区别及使用

众所周知,我们在写sql时经常会用到多表查询数据,这就是涉及到连接的问题包括,左连接,右连接,内连接,全外连接。

定义:

左连接 (left join):返回包括左表的所有记录和右表中连接字段相等的记录

右连接(right join):返回包括右表的所有记录和左表中连接字段相等的记录

等值连接或者叫内连接(inner join):只返回两表相连相等的行

全外连接(full join):返回左右表中所有的记录和左右表中连接字段相等的记录。

只说概念还不够清晰举个例子就懂了!

A表:
  
id      name     
1       张三
2       李四
3       王五
B表;
   
id      A_id       class
1       1          一年一班
2       4          一年二班 

如上有两张表A表为学生表存id和姓名,B表为班级表存id,学生id,班级名。

来吧,展示

内连接:(只有2张表匹配的行才能显示)

select a.name,b.class from A a inner join B b on a.id=b.A_id

所以只能显示相连相等的行及A表id为1和B表A_id为一的

name   class
张三    一年一班

左连接:

select a.name,b.class from A a left join B b on a.id-b.A_i`在这里插入代码片`d

左表只有三条就显示三条 和右表没有相等字段补bull

name     class
张三     一年一班
李四     null
王五     null

右连接

select a.name,b.class from A a right join B b on a.id=b.A_id

右表只有两条就显示两条 和左表没有相等字段补null

name     class
张三     一年一班
null     一年二班

全连接

select a.name,b.class from A a full join B b on a.id=b.A_id

全部显示

name      class
张三      一年一班
null      一年二班
李四      null
王五      null

难度在高一点就是嵌套连接,去连接连接之后的新表等等。好好研究吧

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/192971.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java 安全之Weblogic 2017-3248分析

    Java安全之Weblogic2017-3248分析0x00前言在开头先来谈谈前面的绕过方式,前面的绕过方式分别使用了streamMessageImpl和MarshalledObject对

    2021年12月12日
    59
  • C++ 逻辑与或非 逻辑与逻辑或 逻辑非

    C++ 逻辑与或非 逻辑与逻辑或 逻辑非逻辑运算符 与 或 非 amp amp 作用 根据表达式的值返回真值或者假值逻辑非 include iostream usingnamespa intmain 在 C 中 除了 0 都是真 inta 10 cout lt a endl cout a endl system pause return0 逻辑与 iostream

    2025年7月3日
    5
  • shell if条件判断_shell if 判断

    shell if条件判断_shell if 判断,

    2022年8月18日
    8
  • CBIR–Survey.C/GPU优化.Sys搭建「建议收藏」

    CBIR–Survey.C/GPU优化.Sys搭建「建议收藏」基于内容的图像检索(英语:Content-basedimageretrieval,CBIR;或content-basedvisualinformationretrieval),属于图像分析的一个研究领域。基于内容的图像检索目的是在给定查询图像的前提下,依据内容信息或指定查询标准,在图像数据库中搜索并查找出符合查询条件的相应图片。

    2025年10月19日
    3
  • 计算机三级数据库技术笔记

    计算机三级数据库技术笔记文章目录第一章数据库应用系统开发方法1.1数据库应用系统生命周期1.1.1软件工程与软件开发方法1.1.2DBAS生命周期模型1.2规划与分析1.2.1系统规划与定义1.2.2可行性分析1.2.3项目规划1.3需求分析1.3.1数据需求分析1.3.2功能需求分析1.数据处理需求分析2.业务规则需求分析1.3.3性能需求分析1.3.4其他需求分析1.存储需求分析2.安全…

    2022年6月18日
    33
  • maven配置本地仓库位置「建议收藏」

    maven配置本地仓库位置「建议收藏」在下载好的maven文件中我创建了一个文件夹,做为我的maven的本地仓库接下来就是在conf文件夹中打开setting.xml文件找到这个标签,里面配置刚刚我创建的文件夹的地址,这个地址就配置成了我的本地仓库啦以后下载的依赖就都在这个文件夹下了…

    2022年9月23日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号