zoukankan      html  css  js  c++  java
  • mysql中left join设置条件在on与where时的区别

    一、首先我们准备两张表来进行测试。

    CREATE TABLE `a` (
      `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
      `name` varchar(32) DEFAULT '' COMMENT '名称',
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    
    CREATE TABLE `b` (
      `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',
      `a_id` int(11) DEFAULT '0' COMMENT 'a表ID',
      `name` varchar(32) DEFAULT '' COMMENT '名称',
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    

    两个表的数据如图所示:

    运行下面左连接查询:

    select * from a left join b on a.id = b.a_id;
    

    我们分别在on和where后面加上条件,看看执行结果是否相同。

    select * from a left join b on a.id = b.a_id and b.id > 3;
    

    select * from a left join b on a.id = b.a_id where b.id > 3;
    

    上面的两条语句,条件我们设置的是一样的都是b.id > 3,为什么显示结果不同。

    sql语句查询的关键字顺序一般为 from > where > group by > having > order by

    left join 在 from范围,on 条件会先对 left join 的右表进行筛选,筛选完后的结果 where 再进行筛选。

    多个 left join 会生成一张临时表,on 条件是对 left join 右表进行条件过滤,where 条件针对最后生成的临时表进行过滤。

    所以:

    b.id > 3 的条件如果写在 on 后面,则是先对右边表(关联表)进行筛选,得出符合条件的行,然后主表 left join ,返回主表所有的行,右边表没匹配上的用 null 表示。

    b.id > 3 的条件如果写在 where 后面,则是先主表 left join 右边表(关联表),返回所有的行,然后 where 条件再对结果进行筛选。

    注意:on 后面的条件是针对右边的表(关联表),对主表没什么作用。

    select * from a left join b on a.id = b.a_id and a.id > 3;
    

    我们在on 后面添加了对主表的条件 a.id > 3,不过主表的数据仍然全部显示出来了,但是影响了右边表(关联表)的显示。

    如果想要对主表进行筛选,应该把条件写在where后。

    select * from a left join b on a.id = b.a_id where a.id > 3;
    

  • 相关阅读:
    SharePoint 2013 配置启用搜索服务
    SharePoint 2013 安装图解
    SharePoint 2013 添加Ribbon菜单
    SharePoint 入门介绍
    SharePoint 2007 管理中心TimerJob”计时器作业定义”页面报错
    SharePoint 2007 单列表模糊查询SPD定制
    SharePoint 开发TimerJob 介绍
    SharePoint 搜索爬网第三方网站配置
    SharePoint 2013 配置开发环境,需安装VS2012插件
    SharePoint 2013 中将 HTML文件转换为母版页
  • 原文地址:https://www.cnblogs.com/jkko123/p/10148927.html
Copyright © 2011-2022 走看看