• join、inner join、left join、right join、outer join的区别


    内连接
    inner join(等值连接):只显示两表联结字段相等的行,(很少用到,最好别用);

    外连接
    left join:以左表为基础,显示左表中的所有记录,不管是否与关联条件相匹配,而右表中的数据只显示与关联条件相匹配的记录,不匹配的记录以NULL字符填充

    right join:以右表为基础,显示左表中的所有记录,不管是否与关联条件相匹配,而左表中的数据只显示与关联条件相匹配的记录,不匹配的记录以NULL字符填充

    full join :显示多个表中的所有的记录,不匹配关联条件的列以NULL字符填充.

    例:

    A表:
    id name
    1 a1
    2 a2
    3 a3

    B表:
    id class
    1 b1
    2 b2
    4 b4
    两表相连:
    select a.id,a.name,b.class from A a inner join B b on a.id = b.id
    得出结果:
    1 a1 b1
    2 a2 b2

    两表相连:
    select a.id,a.name,b.class from A a left join B b on a.id = b.id
    得出结果:
    1 a1 b1
    2 a2 b2
    3 a3 null

    两表相连:
    select a.id,a.name,b.class from A a right join B b on a.id = b.id
    得出结果:
    1 a1 b1
    2 a2 b2
    4 null b4

    参考链接: https://www.cnblogs.com/huzi007/p/4630001.html

    什么是联结?

    union、intersect等集合运算,它的特征是以 “行” 为单位进行操作,通俗点说,就是进行这些集合运算,会导致记录行数的增减,使用union会增加记录行数,使用 intersect 或 expect 会减少行记录,集合运算不会导致 “列” 数量的改变。而联结(join) 操作,就是将其他表中的列添加过来,进行 “列添加”的运算。当需要从多张表中取出不同的列组成一个新的查询结果时,就需要用的联结(join)运算了。以下是几种联结运算的简单说明。

    1、join 和 inner join是一样的,为了简写省掉 inner 可直接写为 join, 内联结,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,如下;

     

    2、left join 左联结,就是“左联结”,表1 left join 表2,以左为主,表示以表1为主,关联上表2的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下

     

    3、right join “右联结”,表1 right join 表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2所有数据以及表1和表2有交集的数据,如下:

     

    4、outer join,在MySQL中, 外联结必须指定主表,需指定左右,也即 left outer join,right outer join,实际上,就是 left join 和 right join,为了方便书写把outer省略掉了,在Oracle中,支持全外联结,即 full outer join;

    5、下图可以囊括联结的所有情况

     

    6、交叉联结 CROSS JOIN (也就是耳熟能详的的笛卡尔积),交叉联结的结果是两个表中行数的乘积,交叉联结的结果中包含了内连接,外连接,全连接的所有结果。实际业务中很少会使用交叉联结,因为交叉联结的记过没有实用价值,运算结果函数太多,需要浪费很多运算性能。

  • 相关阅读:
    虹科示波器 | 汽车免拆检修 | 2010款江铃陆风X8车发动机怠速抖动、加速无力
    【老生谈算法】matlab算法离合器——离合器
    微软真是活菩萨,面向初学者的机器学习、数据科学、AI、LLM课程统统免费
    Memcached 的安装与使用;SpringBoot 整合 Memcached 代码详解
    解读以下产生m个k位数的验证码的代码
    ZYNQ移植uCOSIII
    在 Ubuntu 22.04安装配置 Ansible
    网络安全(黑客)自学
    DSA之图(2):图的存储结构
    俄罗斯欲推国产应用取代 Google Play
  • 原文地址:https://blog.csdn.net/qq_44543774/article/details/133933253