一条sql是如何执行的详解
1. SQL 解析(Parsing)
2. 查询重写(Query Rewrite)
3. 查询规划(Query Planning)
4. 查询执行(Query Execution)
5. 结果返回
示例:查询执行流程
总结
边走、边悟迟早会好 |
一条 SQL 查询在 PostgreSQL(以及大多数关系型数据库)中的执行过程可以分为多个阶段。每个阶段都对应特定的任务,从 SQL 解析到最终获取查询结果。以下是 SQL 查询执行过程的详细拆解:
当用户提交一条 SQL 语句后,PostgreSQL 首先进入解析阶段。这个阶段主要有以下几个步骤:
SELECT
是否紧跟着字段名等。输出:在这个阶段,SQL 语句被转换为一个内部的解析树(parse tree)。
在解析树生成后,PostgreSQL 会检查是否有任何规则(rules)适用,并根据这些规则对查询进行重写。重写规则(如视图的定义)可能会改变原始的 SQL 查询,生成新的查询树。
例如:
输出:生成经过重写的查询树。
这个阶段,查询规划器(Query Planner)负责将重写后的查询树转换为执行计划。查询规划器会决定如何最有效地访问数据,主要涉及以下步骤:
PostgreSQL 使用统计信息(如表中行的数量、索引的选择性、列的分布等)来进行成本估算。
输出:生成最终的执行计划(execution plan),这是系统决定如何执行查询的详细步骤。
一旦执行计划确定下来,查询执行器(Query Executor)开始按照计划一步步执行操作。主要的执行步骤包括:
扫描(Scan):执行器按照计划选择的扫描方式(如顺序扫描、索引扫描)读取数据。
过滤(Filter):对于每一行数据,执行器会根据 WHERE
子句条件进行过滤,确保仅保留符合条件的行。
连接(Join):如果查询涉及多个表,执行器会根据选择的连接算法(如嵌套循环连接、哈希连接)对这些表的数据进行连接处理。
排序(Sort)和分组(Group):如果查询要求对数据进行排序(ORDER BY
)或分组(GROUP BY
),执行器会在获取数据后进行这些操作。
投影(Projection):执行器会根据 SELECT
子句中的字段选择要返回的列,并忽略未被选中的列。
返回结果:最终结果集根据执行计划一步步执行并返回给客户端。
执行器生成的结果集会逐行或批量地返回给客户端,直到所有匹配的记录都返回。
假设你有一个简单的查询:
SELECT name, salary FROM employees WHERE department_id = 10 ORDER BY salary DESC;
SQL 解析:
SELECT
、name
、salary
、employees
、WHERE
、department_id
、ORDER BY
、DESC
。employees
表是否存在,name
、salary
、department_id
是否是合法字段。查询重写:
employees
是一个视图,SQL 会被重写为查询基础表。查询规划:
department_id
的索引。如果有索引,可以使用索引扫描来提高效率。查询执行:
employees
表中查找 department_id = 10
的记录。salary
列对数据进行排序。结果返回:
salary
排序后的记录逐行返回给客户端。SQL 查询的执行过程分为解析、查询重写、查询规划、查询执行和结果返回五个主要步骤。每个步骤都对应特定的任务,从解析 SQL 到最终返回结果,确保查询尽可能高效地执行
感谢支持 听忆.-CSDN博客
众口难调从心就好 |