首页 数据库 SQL sql执行顺序是什么

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

热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

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

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1668
14
CakePHP 教程
1427
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
SQL:命令,mysql:引擎 SQL:命令,mysql:引擎 Apr 15, 2025 am 12:04 AM

SQL命令在MySQL中分为DQL、DDL、DML、DCL和TCL五类,用于定义、操作和控制数据库数据。MySQL通过词法分析、语法分析、优化和执行等阶段处理SQL命令,并利用索引和查询优化器提升性能。使用示例包括SELECT用于数据查询,JOIN用于多表操作。常见错误有语法、逻辑和性能问题,优化策略包括使用索引、优化查询和选择合适的存储引擎。

SQL和MySQL:了解核心差异 SQL和MySQL:了解核心差异 Apr 17, 2025 am 12:03 AM

SQL是一种用于管理关系数据库的标准语言,而MySQL是一个具体的数据库管理系统。SQL提供统一语法,适用于多种数据库;MySQL轻量、开源,性能稳定但在大数据处理上有瓶颈。

SQL与MySQL:澄清两者之间的关系 SQL与MySQL:澄清两者之间的关系 Apr 24, 2025 am 12:02 AM

SQL是一种用于管理关系数据库的标准语言,而MySQL是一个使用SQL的数据库管理系统。SQL定义了与数据库交互的方式,包括CRUD操作,而MySQL实现了SQL标准并提供了额外的功能,如存储过程和触发器。

用于数据分析的SQL:商业智能的高级技术 用于数据分析的SQL:商业智能的高级技术 Apr 14, 2025 am 12:02 AM

SQL的高级查询技巧包括子查询、窗口函数、CTE和复杂JOIN,能够处理复杂数据分析需求。1)子查询用于找出每个部门工资最高的员工。2)窗口函数和CTE用于分析员工的薪资增长趋势。3)性能优化策略包括索引优化、查询重写和使用分区表。

SQL:如何克服学习障碍 SQL:如何克服学习障碍 Apr 26, 2025 am 12:25 AM

要成为SQL高手,应掌握以下策略:1.了解数据库基础概念,如表、行、列、索引。2.学习SQL的核心概念和工作原理,包括解析、优化和执行过程。3.熟练使用基本和高级SQL操作,如CRUD、复杂查询和窗口函数。4.掌握调试技巧,使用EXPLAIN命令优化查询性能。5.通过实践、利用学习资源、重视性能优化和保持好奇心来克服学习挑战。

SQL和MySQL:数据管理初学者指南 SQL和MySQL:数据管理初学者指南 Apr 29, 2025 am 12:50 AM

SQL和MySQL的区别在于,SQL是用于管理和操作关系数据库的语言,而MySQL是实现这些操作的开源数据库管理系统。1)SQL允许用户定义、操作和查询数据,通过命令如CREATETABLE、INSERT、SELECT等实现。2)MySQL作为RDBMS,支持这些SQL命令,并提供高性能和可靠性。3)SQL的工作原理基于关系代数,MySQL通过查询优化器和索引等机制优化性能。

SQL的重要性:数字时代的数据管理 SQL的重要性:数字时代的数据管理 Apr 23, 2025 am 12:01 AM

SQL在数据管理中的作用是通过查询、插入、更新和删除操作来高效处理和分析数据。1.SQL是一种声明式语言,允许用户以结构化方式与数据库对话。2.使用示例包括基本的SELECT查询和高级的JOIN操作。3.常见错误如忘记WHERE子句或误用JOIN,可通过EXPLAIN命令调试。4.性能优化涉及使用索引和遵循最佳实践如代码可读性和可维护性。

MySQL:SQL的特定实现 MySQL:SQL的特定实现 Apr 13, 2025 am 12:02 AM

MySQL是开源的关系型数据库管理系统,提供了标准SQL功能和扩展。1)MySQL支持标准SQL操作如CREATE、INSERT、UPDATE、DELETE,并扩展了LIMIT子句。2)它使用InnoDB和MyISAM等存储引擎,适用于不同场景。3)用户可以通过创建表、插入数据和使用存储过程等高级功能高效使用MySQL。

See all articles