0

0

SQL数据库SQL执行算子_过滤投影连接解析

冰川箭仙

冰川箭仙

发布时间:2026-01-09 18:26:37

|

143人浏览过

|

来源于php中文网

原创

SQL执行计划中Filter、Projection、Join是三大核心算子:Filter按条件筛行,影响索引下推;Projection裁剪输出列,决定IO与内存开销;Join实现多表关联,含Nested Loop、Hash、Sort-Merge三种策略。

sql数据库sql执行算子_过滤投影连接解析

SQL执行计划中的算子,是数据库引擎实际执行查询时的底层操作单元。理解过滤(Filter)、投影(Projection)、连接(Join)这三类核心算子,能帮你快速定位慢查询瓶颈、读懂执行计划、写出更高效的SQL。

过滤(Filter):WHERE和HAVING背后的“筛子”

Filter算子负责按条件筛选行,对应SQL中的WHERE(作用于单表或连接前)和HAVING(作用于分组后)。它不改变列结构,只减少行数。

  • 索引是否生效,关键看Filter是否能下推到存储层——比如WHERE create_time > '2024-01-01'若字段有索引,通常会转为Index Range Scan,而非全表扫描后Filter
  • 写WHERE时避免在字段上用函数或表达式,如WHERE YEAR(create_time) = 2024会让Filter无法利用索引,变成全表扫描+计算过滤
  • HAVING过滤发生在GROUP BY之后,开销通常比WHERE大;能用WHERE提前过滤的,别拖到HAVING

投影(Projection):SELECT列表决定的“列裁剪”

Projection算子负责输出指定列(包括计算列、别名、常量),它不筛选行,但影响数据传输量和内存占用

Content at Scale
Content at Scale

SEO长内容自动化创作平台

下载
  • SELECT *会触发全列Projection,即使业务只用其中2列,也会把所有字段从磁盘读出、网络传回,浪费IO和带宽
  • 聚合查询中,Projection还包含GROUP BY字段和聚合函数结果,如SELECT dept, COUNT(*) FROM emp GROUP BY dept,Projection需保留dept值并构造count列
  • 某些优化器会在Projection阶段做常量折叠(如SELECT 1+1 AS c直接算成2)或表达式简化,减少后续计算

连接(Join):多表关联的三种典型实现

Join算子把多个表按关联条件组合成新行集,主流实现方式有Nested Loop Join、Hash Join、Sort-Merge Join,选择取决于数据量、分布、索引和统计信息。

  • Nested Loop:适合小表驱动大表,外层每行去内层查匹配行;若内表关联字段无索引,性能急剧下降
  • Hash Join:先对小表建哈希表,再扫描大表探测匹配;要求内存足够,且一般要求等值连接(=),不支持或范围条件
  • Sort-Merge:两表先按连接键排序,再归并匹配;适合已排序数据或大表间等值/范围连接,但排序开销高
  • 注意连接顺序:优化器通常选行数少、过滤强的表作驱动表;手动调优可用STRAIGHT_JOIN(MySQL)或LEADING(Oracle)干预

这三个算子不是孤立运行的,而是嵌套组合:比如一个JOIN后面接FILTER再接PROJECTION,执行计划树里它们层层包裹。看懂它们各自的输入输出、代价来源和依赖条件,比死记“走索引”“用Hash”更有实际价值。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1094

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

413

2024.04.29

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号