


The content of this article is about the sequence of statement execution in MySQL and the analysis of the query processing stage. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.
MySQL statements are divided into 11 steps in total, as marked in the figure below. The FROM operation is always executed first, and the LIMIT operation is executed last. Each operation will generate a virtual table, which is used as an input for processing. However, these virtual tables are transparent to the user, but only the last virtual table will be returned as a result. If the corresponding operation is not specified in the statement, the corresponding step will be skipped.
(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>
Let’s analyze each stage of query processing in detail
1. FORM: Calculate the Cartesian product of the table on the left and the table on the right of FROM. Generate virtual table VT1
2, ON: Perform ON filtering on virtual table VT1, and only those rows that meet the
3. JOIN: If OUTER JOIN (such as left join, right join) is specified, the unmatched rows in the retained table will be added to virtual table VT2 as external rows. To generate virtual table VT3, if the rug from clause contains more than two tables, then steps 1 to 3 will be repeated for the result VT3 generated by the previous join connection and the next table until all are processed. to the table.
4. WHERE: Perform WHERE condition filtering on virtual table VT3. Only records that meet the
5. GROUP BY: Group the records in VT4 according to the columns in the group by clause to generate VT5.
6. CUBE | ROLLUP: Perform cube or rollup operation on table VT5 to generate table VT6.
7, HAVING: Apply having filter to virtual table VT6, only those that meet 8. SELECT: Perform a select operation, select the specified column, and insert it into virtual table VT8. 9. DISTINCT: Deduplicate records in VT8. Generate virtual table VT9. 10, ORDER BY: Sort the records in virtual table VT9 according to 11. LIMIT: Take out the records of the specified row, generate virtual table VT11, and return the result. Related recommendations: What are the differences between utf8 and utf8mb4 in mysql? How to modify the length limit of the group_conca function in mysql
The above is the detailed content of Analysis of the order of statement execution in mysql and the query processing stage. For more information, please follow other related articles on the PHP Chinese website!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

WebStorm Mac version
Useful JavaScript development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
