zoukankan      html  css  js  c++  java
  • SQL中大概有这么几种JOIN

     SQL中大概有这么几种JOIN

    cross join

    inner join

    left outer join  

    right outer join 

    full outer join

     

    首先都是基于cross join(笛卡尔乘积),然后是inner join,在笛卡尔乘积的结果集中去掉不符合连接条件的行。

    left outer join 是在inner join的结果集上加上左表中没被选上的行,行的右表部分每个字段都用NUll填充。

    right outer join 是在inner join的结果集上加上右表中没被选上的行,行的左表部分全用NULL填充。

    SQL JOIN 用法完全版

    一、各种JOIN的含义

    SQL中大概有这么几种JOIN

    cross join

    inner join

    left outer join  

    right outer join 

    full outer join

     

    首先都是基于cross join(笛卡尔乘积),然后是inner join,在笛卡尔乘积的结果集中去掉不符合连接条件的行。

    left outer join 是在inner join的结果集上加上左表中没被选上的行,行的右表部分每个字段都用NUll填充。

    right outer join 是在inner join的结果集上加上右表中没被选上的行,行的左表部分全用NULL填充。

    outer的意思就是"没有关联上的行"。

     

    二、旧式写法和标准写法:

     

    1INNER Join code as the following:

     

    Select * from A a, B b where a.categoryID = b.categoryID;

    Equals:

    Select * from A a inner join B b on a.categoryID = b.categoryID;

     

    2OUTER Join code as the following

     

    select * from A a full(left/right) outer  join B b  on a on a.categoryID = b.categoryID;

    Equals::

    Select * from A a, B b where a.categoryID *=  b.categoryID;

    Select * from A a, B b where a.categoryID =*  b.categoryID;

     

    三、例子

    Table A have 12( 8+4) entries, 8 entries have valid relation with B

    Table B have 80(77+3) entries , 77 entries have valid relation with A.

     

    then the return amount of join is :

    cross join : 12*80

    inner join : 77

    full outer join : 77+4+3

    left outer join: 77 + 4

    right outrer join: 77 + 3

  • 相关阅读:
    闭包
    TCL
    [Go] gin框架渲染html字符串
    [Go] 使用packr包把静态文件打包进二进制内
    [javascript] 获取正则子表达式里的内容
    [redis] Zremrangebylex命令移除元素令人困惑不能理解
    [Go] 获取文件夹下面指定模式的文件列表 , 并且获取文件创建时间删除超过30分钟的文件
    [vuejs] 聊天框在overflow:auto中填数据时滚动到底部
    [vuejs] 在vuejs中使用websocket进行实时通讯
    Egret顶级开发者—李昌平
  • 原文地址:https://www.cnblogs.com/moonwind/p/4569193.html
Copyright © 2011-2022 走看看