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

  • 相关阅读:
    保研复习数据结构记(8)--排序
    激活WinEdt 11.1
    .NET 7 性能改进 -- 至今为止最快的.NET平台
    记一次springboot @Async处理导致后续request请求参数获取为空的坑
    从简历被拒到收割 8个大厂offer,我用2个月的时间破茧成蝶
    Java之消息推送浅入浅出
    CMT2380F32模块开发17-ADC例程
    SpringBoot 整合 MyBatis-Plus
    达人评测 r5 6600u和锐龙R7 6800h选哪个 r56600u和R76800h对比
    我会在以下情况用到GPT
  • 原文地址:https://blog.csdn.net/qq_44543774/article/details/133933253