搜索
首页数据库SQLsql执行顺序是什么

sql执行顺序是什么

Jun 10, 2019 am 10:36 AM

sql执行顺序是什么

SQL语句的执行顺序

MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是FROM操作,最后执行的是LIMIT操作。其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入,只是这些虚拟的表对用户来说是透明的,但是只有最后一个虚拟的表才会被作为结果返回。如果没有在语句中指定某一个子句,那么将会跳过相应的步骤。

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

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

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

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

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

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

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

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

SELECT: 执行select操作,选择指定的列,插入到虚拟表VT8中。

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

ORDER BY: 将虚拟表VT9中的记录按照进行排序操作,产生虚拟表VT10.

LIMIT:取出指定行的记录,产生虚拟表VT11, 并将结果返回。

写的顺序:select ... from... where.... group by... having... order by.. limit [offset,] 

(rows)

执行顺序:from... where...group by... having.... select ... order by... limit

以上是sql执行顺序是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
OLTP与OLAP:那大数据呢?OLTP与OLAP:那大数据呢?May 14, 2025 am 12:06 AM

Oltpandolaparebothestential forBigdata:oltphandlesleal-Timetransactions,whereLapanalyzeslargedAtasetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetsetscalingcalingtechnologieslikenosqlforbigdata

SQL中的模式匹配是什么?它如何工作?SQL中的模式匹配是什么?它如何工作?May 13, 2025 pm 04:09 PM

patternMatchingInsqlusestHelikeOperatorAndRegulareSearchSearchForceSearchPatterns.itenablesflexibledataqueryingwithWildCardslike%and_,andregexforcomplexmatches.it'sversatilebutrequirescarefuilusetetoetoetoavovoidperformanceSissUseSissUseSuseSuseSuseSuseSuseSuseSuseSuseSuseSuseSuseDoveruse。

学习SQL:了解挑战和奖励学习SQL:了解挑战和奖励May 11, 2025 am 12:16 AM

学习SQL需要掌握基础知识、核心查询、复杂JOIN操作和性能优化。1.理解表、行、列等基本概念和不同SQL方言。2.熟练使用SELECT语句进行查询。3.掌握JOIN操作从多表获取数据。4.优化查询性能,避免常见错误,使用索引和EXPLAIN命令。

SQL:揭示其目的和功能SQL:揭示其目的和功能May 10, 2025 am 12:20 AM

SQL的核心概念包括CRUD操作、查询优化和性能提升。1)SQL用于管理和操作关系数据库,支持CRUD操作。2)查询优化涉及解析、优化和执行阶段。3)性能提升可以通过使用索引、避免SELECT*、选择合适的JOIN类型和分页查询实现。

SQL安全最佳实践:保护数据库免受漏洞SQL安全最佳实践:保护数据库免受漏洞May 09, 2025 am 12:23 AM

防止SQL注入的最佳实践包括:1)使用参数化查询,2)输入验证,3)最小权限原则,4)使用ORM框架。通过这些方法,可以有效保护数据库免受SQL注入和其他安全威胁。

MySQL:SQL的实际应用MySQL:SQL的实际应用May 08, 2025 am 12:12 AM

MySQL受欢迎的原因是其性能卓越且易于使用和维护。1.创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2.插入和查询数据:通过INSERTINTO和SELECT语句操作数据。3.优化查询:使用索引和EXPLAIN语句提升性能。

比较SQL和MySQL:语法和功能比较SQL和MySQL:语法和功能May 07, 2025 am 12:11 AM

SQL和MySQL的区别与联系如下:1.SQL是标准语言,用于管理关系数据库,MySQL是基于SQL的数据库管理系统。2.SQL提供基本CRUD操作,MySQL在此基础上增加了存储过程、触发器等功能。3.SQL语法标准化,MySQL在某些地方有改进,如LIMIT用于限制返回行数。4.使用示例中,SQL和MySQL的查询语法略有不同,MySQL的JOIN和GROUPBY更直观。5.常见错误包括语法错误和性能问题,MySQL的EXPLAIN命令可用于调试和优化查询。

SQL:初学者指南 - 学习容易吗?SQL:初学者指南 - 学习容易吗?May 06, 2025 am 12:06 AM

sqlisytolearnforbeginnersduetoitsstraightStraightSandAxandBasicCoperations,butmasteringItInVolvesComplexConcepts.1)startwithSimplequeriesLikeSlect,Insert,inters,Update,Update,update,deasts,delete.2)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具