zoukankan      html  css  js  c++  java
  • 【mySQL】left join、right join和join的区别

    哈,好久没更新文章了,今天来说说关于mySQL那些年的小事。说到mySQL啊,用了挺久的了,但是有个问题一直在困扰着我,就是left join、join、right join和inner join等等各种join的区别。网上搜,最常见的就是一张图解图,如下:

    clipboard.png

    真的是一张图道清所有join的区别啊,可惜我还是看不懂,可能人比较懒,然后基本一个left join给我就是够用的了,所以就没怎么去仔细研究了,但是现实还是逼我去搞清楚,索性自己动手,总算理解图中的含义了,下面就听我一一道来。

    首先,我们先来建两张表,第一张表命名为kemu,第二张表命名为score:

    clipboard.pngclipboard.png

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

    select
       *
    from
       kemu
    left join score on kemu.id = score.id

    结果集:
    clipboard.pngclipboard.png

    二、right join

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

    select
       *
    from
       kemu
    right join score on kemu.id = score.id

    结果集:

    clipboard.pngclipboard.png

    三、join
    join,其实就是“inner join”,为了简写才写成join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下

    select
       *
    from
       kemu
    join score on kemu.id = score.id

    结果集:

    clipboard.pngclipboard.png

    以上就是三种连接的区别!

    https://segmentfault.com/a/1190000017369618

    欢迎关注微信公众号:大数据从业者
  • 相关阅读:
    ZZ
    Qt5获取网卡/IP等信息
    platforms
    [转]如何使用VS 2013發布一個可以在Windows XP中獨立運行的可執行文件
    spring cloud 服务提供者
    spring cloud: eureka搭建
    通过maven 上传jar 到nexus3,cong nexus3下载jar
    搭建turbine时 hystrix MaxConcurrentConnections reached 异常
    Zuul超时问题,微服务响应超时,zuul进行熔断
    微信公众号开发网址
  • 原文地址:https://www.cnblogs.com/felixzh/p/15728049.html
Copyright © 2011-2022 走看看