SQL语句执行顺序

文章目录

  • SQL 简介
  • SQL 语句的执行顺序
  • 重点

SQL 简介

SQL 是 Structured Query Language 的缩写,称为结构化查询语言,SQL 是一种操作关系型数据库的规则,SQL 语句以分号结尾,不区分大小写,建议关键词使用大写。

SQL 语句的执行顺序

(7) SELECT
(8) DISTINCT <select_list>
(1) FROM <left_table>
(3) <join_type> JOIN <right_table>
(2) ON <join_condition>
(4) WHERE <where_condition>
(5) GROUP BY <group_by_list>
(6) HAVING <having_condition>
(9) ORDER BY <order_by_condition>
(10) LIMIT <limit_number>
在这里插入图片描述

下面我们来具体分析一下查询处理的每一个阶段:

FORM:FROM 的左边的表和右边的表计算笛卡尔积。产生虚拟表 VT1

ON: 对虚拟表 VT1 进行 ON 筛选,只有那些符合 <join-condition> 的行才会被记录在虚拟表 VT2 中。

JOIN: 如果指定了 OUTER JOIN(比如 left joinright join),那么保留表中未匹配的行就会作为外部行添加到虚拟表 VT2 中,产生虚拟表 VT3, 如果 from 子句中包含两个以上的表的话,那么就会对上一个 join 连接产生的结果 VT3 和下一个表重复执行步骤1~3这三个步骤,一直到处理完所有的表为止。

WHERE: 对虚拟表 VT3 进行 WHERE 条件过滤。只有符合 <where-condition> 的记录才会被插入到虚拟表 VT4 中。

GROUP BY: 根据 group by 子句中的列,对 VT4 中的记录进行分组操作,产生虚拟表 VT5

CUBE | ROLLUP: 对表 VT5 进行 cube 或者 rollup 操作,产生虚拟表 VT6

HAVING: 对虚拟表 VT6 应用 having 过滤,只有符合 <having-condition> 的记录才会被 插入到虚拟表 VT7 中。

SELECT: 执行 select 操作,选择指定的列,并对字段进行处理,计算 select 子句中的表达式,产生虚拟表 VT8

DISTINCT:VT8 中的记录进行去重。产生虚拟表 VT9

ORDER BY: 将虚拟表 VT9 中的记录按照 <order_by_list> 进行排序操作,返回游标 VC10,而不是虚拟表。SQL 是基于集合理论的,集合不会预先对它的行排序,它只是成员的逻辑集合,成员的顺序是无关紧要的。对表进行排序的查询可以返回一个对象,这个对象包含特定的物理顺序的逻辑组织。这个对象就叫游标。正因为返回值是游标,那么使用 ORDER BY 子句查询不能应用于表表达式。排序是很需要成本的,除非你必须要排序,否则最好不要指定 ORDER BY。这一步是第一步也是唯一一步可以使用 SELECT 列表中的列别名的步骤。

LIMIT:VC10 的开始处选择指定数量行,生成虚拟表 VT11,并将结果返回。

写的顺序:

select ... from... where.... group by... having... order by.. limit...

执行顺序:

from... where...group by... having.... select ... order by... limit... 

重点

错误的理解:

select … where,where 子句比 selec 子句先执行,但是数据库是逐行判断的,也就是说数据库在执行 SQL 语句时,指针会移动到表中的第一行,先判断第一行记录是否满足 where 子句的条件,满足则执行 select 子句,将整行记录的所有字段值存储到虚拟表中(注意:如果 select 子句中自定义了其它字段,那么这个步骤会将自定义的字段及相关的字段值存储到虚拟表中)。接着移动指针到下一行,再判断是否满足 where 子句的条件;如果不满足则放弃该条记录,接着指针移到下一行,再判断是否满足 where 子句的条件。重复上述的流程直到无记录可读取为止。

但是最终在返回查询结果时,selec 子句指定了什么字段,返回的结果集中则包含哪些字段。

正确的理解:

先逐行判断记录是否满足 where 子句的条件,不满足则放弃,满足则将整行记录的字段值存储到虚拟表 VT0 中,直到整张表的数据筛选完成后,再执行 select 子句从虚拟表 VT0 中获取指定的列和值到虚拟表 VT1 中,最后将结果返回。

如果 select 子句中含有变量表达式,在执行 where 子句时,有时候这些表达式会同步进行计算,而有的时候不会计算,具体什么情况下会计算,什么情况下不会计算,我也不清楚。但是这里要提醒的是,即便表达式同步计算了,并不表示 select 子句在执行,所以不要以为变量的值发生变化了就认为 where 子句执行完后紧跟着就执行了 select 子句,其实并不是这样的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/335523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

getexternalfilesdir 相册_音乐相册(电子相册制作)V5.2 安卓最新版

音乐相册(电子相册制作)是一个功能强大的电子相册创建工具。最新版本的音乐专辑应用程序可以帮助用户快速创建精美的多媒体专辑视频&#xff0c;并匹配优美的音乐伴奏&#xff0c;使照片更精彩。音乐专辑应用程序支持几乎所有流行的图片格式&#xff0c;并支持导入和导出&#…

jdk 9和jdk8_JDK 9是某些功能的终结

jdk 9和jdk8几天前宣布JDK 9是Feature Complete&#xff01; 进行切割的许多“功能”是附加功能&#xff0c;但有些是移除功能。 这篇文章介绍了一些从OpenJDK和/或Oracle JDK with Java 9中删除的项目。 JEP 220 &#xff08;“模块化运行时图像”&#xff09;的一部分是删除…

二级java题型及分值_2016年全国计算机二级java语言程序设计考试大纲

2016年全国计算机二级java语言程序设计考试大纲2016年3月计算机考试即将在3月26日-29日进行&#xff0c;为了帮助大家顺利通过2016年计算机二级考试&#xff0c;下面百分网小编为大家带来2016年全国计算机二级java语言程序设计考试大纲&#xff0c;供大家参考学习&#xff0c;预…

linux系统下安装jdk教程

一、首先下载linux版本jdk jdk官网&#xff1a;http://www.oracle.com/technetwork/java/javase/downloads/index.html 根据自己的需求&#xff0c;下载不同版本的jdk 2.将下载好的jdk压缩包&#xff0c;通过ftp上传到linux系统的当前用户下&#xff0c;我当前登录的用户为r…

mqtt java_MQTT和Java入门

mqtt javaMQTT&#xff08;MQ遥测传输&#xff09;是一种轻量级的发布/订阅消息传递协议。 MQTT在物联网应用程序中得到了广泛使用&#xff0c;因为它被设计为在占用空间小的系统上运行在远程位置。 MQTT 3.1是OASIS标准&#xff0c;您可以在http://mqtt.org/上找到所有信息。…

iphone11什么时候上市_hd3手表高仿哪里买 什么时候上市?

hd3手表高仿哪里买 什么时候上市? 导读&#xff1a;hd3手表高仿哪里买zf的万国7日链高仿表怎么样&#xff1f;款式设计非常出色&#xff0c;很多手表的款式&#xff0c;依靠着该性价比的迅速提升来做出的有效转化&#xff0c;年轻人对于复刻表的选择&#xff0c;能拥有的这些细…

arcgis工具python源码_面向Arcgis的python脚本编程_数据

【实例简介】《面向ArcGIS的Python脚本编程》是一本指导ArcGIS for Desktop专业用户进行Python开发的指南。该书将教会您如何通过编写Python代码处理空间数据并在ArcGIS中自动化实现地理处理任务【实例截图】【核心代码】面向arcgis的python脚本编程数据└── 面向arcgis的pyt…

Windows 命令终端(CMD)程序员常用的命令

文章目录certutilcddirmd/mkdirrddelreplacechdir/cdattribhelptypemorefindstrrename/renset环境变量扩展echonetstattskilltasklisttaskkillnettreecopystartpauseprintverwinversysteminfowmiclogofftracertroute printtelnetftppingipconfigshutdown远程关机formatchkdskti…

驱动级的自动按键_空调遥控器特殊按键使用方法及注意事项

在上门维修过程中&#xff0c;用户常常由于遥控器使用不当&#xff0c;或者幵启了特定按键引起空调器的假性故障&#xff0c;这时需要进行电话解答或上门讲解&#xff0c;现对空调遥控器的特殊功能按键作简单介绍。示例遥控器型号为格力YAD0F,与KFR-23GW/ ( 23570 ) Aa-3挂式空…

净资产滚动率_净资产的结构

净资产滚动率Netty的包装结构很棒。 每个程序员都应该研究它。 每个系统都应该模仿它&#xff1b; 每个项目经理都应将其打印出来&#xff0c;拍在墙上&#xff0c;然后对开发人员说&#xff1a;“那样。” Netty是一个“ ...异步事件驱动的网络应用程序框架&#xff0c;用于…

freebsd nginx php mysql_FreeBSD 安装配置Nginx+PHP+APC+MySQL

在 FreeBSD 下安装软件的传统方法是用 ports 源码安装&#xff0c;不过使用 ports 源码编译安装太耗时(尤其是各种库依赖多、大的时候)&#xff0c;个人还是喜欢 pkg 这种软件包管理工具直接安装编译好的二进制软件包&#xff0c;不用自己编译&#xff0c;省时省力。FreeBSD 也…

python入门之类的基础语法-关于一些Python的一些基础语法训练

1&#xff1a;已知a和b元素 a "pyer" b "apple" 用字典和format方法实现&#xff1a;效果&#xff1a;my name is pyer, i love apple. 1、format的方法 c "mysql name is {0},i love {1}".format("pyer","apple") 用字典…

jdk 9和jdk8_JDK 9已完成功能!

jdk 9和jdk8今天的Mark Reinhold消息JDK 9已完成功能完善-现在该降级了 &#xff0c; 它宣布JDK 9的“总体功能集已冻结”。 OracleJava平台小组的首席架构师Reinhold补充说&#xff1a;“极不可能将任何进一步的JEP定向到该发行版。” 与该消息类似的文本也出现在JDK 9页面上 …

Java从键盘输入若干数_用java编程序:从键盘输入若干个整数,输出这些数中大于其平均值的数。...

展开全部引用1楼 christal yhy的答案,考虑到浮点数的存在,特在此基础上优化一下,代码如下:public static void main(String[] args) {Scanner scan new Scanner(System.in);System.out.println("请输入62616964757a686964616fe59b9ee7ad9431333262373933要输入的个数:&qu…

java多线程编程_阿里P8熬到秃头肝出来的:Java多线程+并发编程核心笔记

自学Java的时候&#xff0c;多线程和并发这一块可以说是最难掌握的部分了&#xff0c;很多小伙伴表示需要一些易于学习和上手的资料。所以今天这本「Java并发学习手册.pdf」就是一份集中学习多线程和并发的手册&#xff0c;PDF版&#xff0c;由RedSpider社区的五位大神撰写&…

内外网逻辑隔离物理隔离_隔离域逻辑

内外网逻辑隔离物理隔离在一个设计模式课程中&#xff0c;我对建模域逻辑进行了有趣的讨论。 具体来说&#xff0c;它是关于隔离域逻辑的 。 一个应用程序通常分为三个部分&#xff1a; 演示&#xff08;例如桌面GUI&#xff0c;浏览器&#xff0c;Web服务&#xff09; 域逻辑…

360安全浏览器兼容模式怎么设置_测试新手一定要知道:最实用的Web兼容性测试经验都在这...

在日常工作中&#xff0c;我们经常碰到网页不兼容的问题。我们之所以要做兼容性测试&#xff0c;目的在于保证待测试项目在不同的操作系统平台上正常运行。主要包括待测试项目能在同一操作系统平台的不同版本上正常运行&#xff1b;待测试项目能与相关的其他软件或系统的“和平…

Linux 的命令终端(CMD)的快捷键(Keyboard of MacBook)

文章目录常用移动光标编辑命令查找历史命令控制命令命令终端界面滚屏命令终端页签切换奇葩常用 快捷键说明Ctrl A光标跳到本行的行首Ctrl E光标跳到本行的行尾Ctrl U删除当前光标前面的所有文字&#xff08;还有剪切功能&#xff09;Ctrl K删除当前光标后面的所有文字&…

instanceof_您真的需要instanceof吗?

instanceof使用instanceof是一种代码味道。 我认为我们可能对此表示同意。 每当我看到这样的构造时&#xff0c;我都会确定出现了问题。 也许有人只是在进行更改时没有注意到问题&#xff1f; 也许有一个主意&#xff0c;但是它太复杂了&#xff0c;以至于需要太多的精力或时间…

HTML 中的节点、元素、标签、标记的区别

文章目录一、HTML 节点&#xff08;一&#xff09;节点的类型二、HTML 标签三、HTML 元素&#xff08;一&#xff09;HTML 元素属性&#xff08;二&#xff09;HTML 元素的嵌套一、HTML 节点 节点&#xff08;node&#xff09;是构成我们网页的最基本的组成部分&#xff0c;网…