on与where的区别

on是先对表进行筛选再生成关联表,where是先生成关联表再对关联表进行筛选,on执行的优先级高于left join,而where的优先级低于left join

当我们使用on关键字时,会先根据on后面的条件进行筛选,条件为真时返回该行,由于on的优先级高于left join,所以left join关键字会把左表中没有匹配的所有行也都返回,然后生成临时表返回

where对与行的筛选是在left join之后的,也就是生成临时表之后才会对临时表进行筛选

比如下面的例子:

SELECT * FROM emp e  LEFT JOIN dept d ON e.deptno=d.deptno AND sal<1000


这里on先对左表进行了筛选,但是left join还是会把坐标中不匹配的行也全部返回

SELECT * FROM emp e LEFT JOIN dept d ON e.deptno=d.deptno WHERE sal<1000


这里由于先生成关联表,然后where才对行进行筛选所以只会剩下三条满足条件的行

总结:

on是先筛选后关联,where是先关联后筛选

on与where的区别相关推荐

  1. RPC 笔记(01)— RPC概念、调用流程、RPC 与 Restful API 区别

    1. 基本概念 PRC 远程过程调用 Remote Procedure Call,其就是一个节点请求另外一个节点提供的服务.当两个物理分离的子系统需要建立逻辑上的关联时,RPC 是牵线搭桥的常见技术手 ...

  2. C++ 笔记(28)— C++ 中 NULL和 nullptr 的区别

    最近看公司代码的时候发现在判断指针是否为空的时候,有的时候用的是 NULL, 有的时候用的是 nullptr 感觉很奇怪,好奇心驱使我查了下两者的区别,发现还是有很多细节需要学习的. 1. NULL ...

  3. gcc 和 g++ 的联系和区别,使用 gcc 编译 c++

    GCC 编译器已经为我们提供了调用它的接口,对于 C 语言或者 C++ 程序,可以通过执行 gcc 或者 g++ 指令来调用 GCC 编译器. 实际使用中我们更习惯使用 gcc 指令编译 C 语言程序 ...

  4. Python2 与 Python3 区别

    Python2.x 与 Python3.x 区别 1. print 函数 Python2 中 print 是语句(statement),Python3 中 print 则变成了函数.在 Python3 ...

  5. Docker 入门系列(1)- 初识容器,镜像、容器、仓库的区别

    Docker 简介 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...

  6. HTTP 协议入门 — (TCP/IP协议族、通信传输流、URI 与 URL 的区别、Cookie 状态管理、HTTP 支持的方法、状态码类别、HTTP 首部字段)

    TCP/IP协议族 在介绍 HTTP 协议之前,我们先对 TCP/IP 协议族有个大概的了解,TCP/IP 协议从上到下主要分为应用层.传输层.网络层和数据链路层,各层的主要功能如下表所示: 协议层 ...

  7. python二进制打开(rb)和文本格式打开(r)什么区别?

    使用 open() 函数以文本格式打开文件和以二进制格式打开文件,唯一的区别是对文件中换行符的处理不同. 在 Windows 系统中,文件中用 "\r\n" 作为行末标识符(即换行 ...

  8. python中__dict__与dir()区别

    前言 Python下一切皆对象,每个对象都有多个属性(attribute),Python对属性有一套统一的管理方案. __dict__与dir()的区别: dir()是一个函数,返回的是list: _ ...

  9. java和C#面向对象的区别

    问题:C#中的构造函数和java的构造函数一样吗? 答: .net的项目中,写实体Entity属性时,经常会为每一个属性写一对get和set方法,在用到这个实体或是一个类时,通过new实例化一个对象, ...

  10. 判别模型和生成模型的区别

    20210703 https://www.zhihu.com/question/20446337 机器学习"判定模型"和"生成模型"有什么区别? 重点 http ...

最新文章

  1. 鱼眼镜头标定基本原理及实现
  2. 技术团队的情绪与效率
  3. LocalDB 静默安装
  4. redis——redis主从复制
  5. 转:关掉Archlinux中烦人的响铃
  6. 50道编程小题目之【质数的个数】
  7. int java 时间,java 时间处理类
  8. Python 06 编码
  9. 搭载Apple芯片的Mac如何使用macOS恢复?
  10. fht算法c语言源码,sklearn中LinearRegression使用及源码解读
  11. autocad 如何摆正显示_AutoCAD使用技巧问答
  12. 手机端App显示jsp页面的注意事项
  13. mysql查询各科成绩的前三名
  14. $(html) 原生js,原生js仿jquery一些常用方法(必看篇)
  15. Ubuntu16.04安装LSD-SLAM
  16. MapReduce: Simplified Data Processing on Large Clusters 翻译和理解
  17. ARM公司为何如此成功
  18. java中北大学ppt总结+课后习题第三章(小宇特详解)
  19. 谷歌浏览器收藏栏不见了解决办法
  20. 【Python turtle 画爱心】实战学习

热门文章

  1. 百年辉煌师心向党 · 德高道厚幸福敬中——2021年石家庄敬业中学教师节庆祝大会
  2. 软件研发落地实践,要从设计就开始
  3. Android抽象任务管理框架QTaskManager及其使用方式介绍
  4. flash在C#中的应用
  5. uni-app在QQ开发者工具上运行
  6. DICOM医学图像处理:fo-dicom网络传输之 C-Echo and C-Store
  7. c语言编程大体思路,C语言:程序的设计思路跟特点
  8. Malformed \uxxxx encoding解决方法
  9. 【Android折叠屏适配】基于AutoSize框架适配折叠屏并兼容多窗口模式
  10. 我在windows10下,使用CMake gui 编译krita源码,CMake gui报错:LibMyPaint_DIR-NOTFOUND