zoukankan      html  css  js  c++  java
  • sql join实例图解

    https://blog.codinghorror.com/a-visual-explanation-of-sql-joins/

    1. inner join:

    所有满足join条件的两个table对应的row,column都将在result set中出现。比如下面的例子条件是tj1.id=tj2.id2而满足这个条件的row.

    它的执行过程可以这样理解:获取tj1的第一行的id字段为1,随后比对tj2的id2字段,发现有三条记录出现,因此在结果集中就有了三条tj1.id=tj2.id2=1的记录,而

    tj1.id=1的记录被复制了三份分别对应着tj2.id2=1的三条记录。接下来去比对tj1.id第二条记录2,在tj2.id2中又发现了2条记录,因此结果集中就出现2条记录。

    继续往下tj1.id第三条记录3,在tj2.id2中只发现了1条记录,因此只出现1条记录。

    2. left outer join

    left outer join返回left table的所有row,并且附带上符合join条件的right table对应的matching row. 

    如果在right table中并没有发现对应列和left table的join条件满足matching,则返回null value

    由于tj2表中有id2为8和9的两列tj1无对应记录存在因此以NULL填充.

    执行的过程同样是先拿出left table的第一行id来检查得出right table的所有行中的id2为1的行,每找到这样一行就将其连同left table 的id=1 value=first形成新的一行(具体结果集出现哪些字段由select信息来决定)

    3. right outer join

    返回所有的right table行,以及满足matching条件的left table行信息,如果左表没有matching到右表对应的join条件时,则返回null.

    执行过程依然是:针对右表的所有行,先取出第一行,再到左表中每一行查看是否有匹配join条件的,如发现满足,则将左表该行信息+右表的这行信息形成一行,直到左表扫描完毕。接下来继续右表的第二行,依次进行!

    4. full outer join

    由于mysql不支持full outer join,我们只能使用left/right outer join + union来模拟操作了。full outer join返回rows from either table when the conditions are met and retunrs a null value when there is no match

    5. cross join

    cross join不需要任何join条件,简单地返回row number1*row number2条记录

    6. equi/non-equi join

    在上面的inner/outer join中,对应的join条件都是t1.x=t2.y这种等值条件,也可以使用任何其他的非等值判断条件,比如t1.x>t2.y

    7. self join

    一个表和自己做inner/outer join

  • 相关阅读:
    关于Vue修改默认的build文件存放的dist路径
    JSON.stringify的三个参数(转载)
    JS获取字符串实际长度(包含汉字)的简单方法
    JSON.stringify() 和 JSON.parse()
    iPhone各种机型尺寸、屏幕分辨率
    jquery each 遍历
    React 內联式样
    组件Refs(操作DOM的2⃣️两种方法)
    可复用组件
    事件与数据的双向绑定
  • 原文地址:https://www.cnblogs.com/kidsitcn/p/6040859.html
Copyright © 2011-2022 走看看