on与where的区别
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的区别相关推荐
- RPC 笔记(01)— RPC概念、调用流程、RPC 与 Restful API 区别
1. 基本概念 PRC 远程过程调用 Remote Procedure Call,其就是一个节点请求另外一个节点提供的服务.当两个物理分离的子系统需要建立逻辑上的关联时,RPC 是牵线搭桥的常见技术手 ...
- C++ 笔记(28)— C++ 中 NULL和 nullptr 的区别
最近看公司代码的时候发现在判断指针是否为空的时候,有的时候用的是 NULL, 有的时候用的是 nullptr 感觉很奇怪,好奇心驱使我查了下两者的区别,发现还是有很多细节需要学习的. 1. NULL ...
- gcc 和 g++ 的联系和区别,使用 gcc 编译 c++
GCC 编译器已经为我们提供了调用它的接口,对于 C 语言或者 C++ 程序,可以通过执行 gcc 或者 g++ 指令来调用 GCC 编译器. 实际使用中我们更习惯使用 gcc 指令编译 C 语言程序 ...
- Python2 与 Python3 区别
Python2.x 与 Python3.x 区别 1. print 函数 Python2 中 print 是语句(statement),Python3 中 print 则变成了函数.在 Python3 ...
- Docker 入门系列(1)- 初识容器,镜像、容器、仓库的区别
Docker 简介 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发 ...
- HTTP 协议入门 — (TCP/IP协议族、通信传输流、URI 与 URL 的区别、Cookie 状态管理、HTTP 支持的方法、状态码类别、HTTP 首部字段)
TCP/IP协议族 在介绍 HTTP 协议之前,我们先对 TCP/IP 协议族有个大概的了解,TCP/IP 协议从上到下主要分为应用层.传输层.网络层和数据链路层,各层的主要功能如下表所示: 协议层 ...
- python二进制打开(rb)和文本格式打开(r)什么区别?
使用 open() 函数以文本格式打开文件和以二进制格式打开文件,唯一的区别是对文件中换行符的处理不同. 在 Windows 系统中,文件中用 "\r\n" 作为行末标识符(即换行 ...
- python中__dict__与dir()区别
前言 Python下一切皆对象,每个对象都有多个属性(attribute),Python对属性有一套统一的管理方案. __dict__与dir()的区别: dir()是一个函数,返回的是list: _ ...
- java和C#面向对象的区别
问题:C#中的构造函数和java的构造函数一样吗? 答: .net的项目中,写实体Entity属性时,经常会为每一个属性写一对get和set方法,在用到这个实体或是一个类时,通过new实例化一个对象, ...
- 判别模型和生成模型的区别
20210703 https://www.zhihu.com/question/20446337 机器学习"判定模型"和"生成模型"有什么区别? 重点 http ...
最新文章
- 鱼眼镜头标定基本原理及实现
- 技术团队的情绪与效率
- LocalDB 静默安装
- redis——redis主从复制
- 转:关掉Archlinux中烦人的响铃
- 50道编程小题目之【质数的个数】
- int java 时间,java 时间处理类
- Python 06 编码
- 搭载Apple芯片的Mac如何使用macOS恢复?
- fht算法c语言源码,sklearn中LinearRegression使用及源码解读
- autocad 如何摆正显示_AutoCAD使用技巧问答
- 手机端App显示jsp页面的注意事项
- mysql查询各科成绩的前三名
- $(html) 原生js,原生js仿jquery一些常用方法(必看篇)
- Ubuntu16.04安装LSD-SLAM
- MapReduce: Simplified Data Processing on Large Clusters 翻译和理解
- ARM公司为何如此成功
- java中北大学ppt总结+课后习题第三章(小宇特详解)
- 谷歌浏览器收藏栏不见了解决办法
- 【Python turtle 画爱心】实战学习
热门文章
- 百年辉煌师心向党 · 德高道厚幸福敬中——2021年石家庄敬业中学教师节庆祝大会
- 软件研发落地实践,要从设计就开始
- Android抽象任务管理框架QTaskManager及其使用方式介绍
- flash在C#中的应用
- uni-app在QQ开发者工具上运行
- DICOM医学图像处理:fo-dicom网络传输之 C-Echo and C-Store
- c语言编程大体思路,C语言:程序的设计思路跟特点
- Malformed \uxxxx encoding解决方法
- 【Android折叠屏适配】基于AutoSize框架适配折叠屏并兼容多窗口模式
- 我在windows10下,使用CMake gui 编译krita源码,CMake gui报错:LibMyPaint_DIR-NOTFOUND