zoukankan      html  css  js  c++  java
  • 数据库之“on”“where”区别

    数据库在通过连接两张或者多张表返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户

         在使用inner join(内连接)没有区别,但是 在使用left jion时,on和where条件的区别如下:

        1、 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。(返回左表全部记录)。此时可能会出现与右表不匹配的记录即为空的记录。

        2、where条件是在临时表生成好后,再对临时表进行过滤的条件。

           

           假设有两张表:表1:tab1

    id
    size
    1
    10
    2
    20
    3
    30

           表2:tab2

    size
    name
     
    10
    AAA
    20
    BBB
    20
    CCC


    两条SQL:
    1、select * form tab1 left join tab2 on (tab1.size = tab2.size) where tab2.name=’AAA’
    2、select * form tab1 left join tab2 on (tab1.size = tab2.size and tab2.name=’AAA’)

    3、select * from tab1 left join tab2 on (tab1.size = tab2.size and tab2.name='AAA') where tab2.id is not null;

    2和3是等价的。只是2中包含了不匹配的结果所有与1不等价。

    第一条SQL的过程:

    1、中间表
    on条件: 
    tab1.size = tab2.size
    tab1.id tab1.size tab2.size tab2.name
    1
    10
    10
    AAA
    2
    20
    20
    BBB
    2
    20
    20
    CCC
    3
    30
    (null)
    (null)
    |
    |

    2、再对中间表过滤
    where 条件:
    tab2.name=’AAA’

    tab1.id tab1.size tab2.size tab2.name
    1
    10
    10
    AAA
       

    第二条SQL的过程:

    1、中间表
    on条件: 
    tab1.size = tab2.size and tab2.name=’AAA’
    (条件不为真也会返回左表中的记录)
    tab1.id tab1.size tab2.size tab2.name
    1
    10
    10
    AAA
    2
    20
    (null)
    (null)
    3
    30
    (null)
    (null)
     
    (转)
  • 相关阅读:
    ASP.NET MVC one view bind many model
    说一说MVC的CustomHandlerErrorAttribute(五)
    今天俺要说一说工厂方法模式(Factory)
    今天俺要说一说简单工厂模式(Simple Factory)
    我对SQL性能优化的看法,对我的文章有提议的欢迎评论!
    Linux 服务管理两种方式service和systemctl
    Linux grep命令
    Linux 守护进程
    linux Ctrl+z和Ctrl+c的区别
    linux系统卡解决方案
  • 原文地址:https://www.cnblogs.com/qiaoyanlin/p/6746502.html
Copyright © 2011-2022 走看看