贝利信息

mysql执行SQL时行数据是如何读取的_mysql数据访问流程

日期:2026-01-21 00:00 / 作者:P粉602998670
MySQL以16KB页为单位从磁盘加载数据到InnoDB缓冲池,未命中则同步读整页;WHERE条件优先在存储引擎层用索引过滤,无法下推的表达式由Server层二次过滤;SELECT列指定可避免读溢出页,LIMIT仅在能索引定位时加速。

MySQL 执行 SELECT 时,数据从磁盘到内存的路径是怎样的

MySQL 不会直接“按行”从磁盘读取数据;它以 page(页)为单位加载数据,InnoDB 默认页大小是 16KB。一次查询哪怕只查 1 行,只要该行不在缓冲池中,就得把整页(含可能几十行)从磁盘读入 innodb_buffer_pool

WHERE 条件是在哪一层过滤的:存储引擎层还是 Server 层

过滤发生在两层协同完成,但关键判断在存储引擎层:

SELECT * 和 SELECT col1, col2 在数据读取上有区别吗

有本质区别,尤其当表包含大字段(TEXTBLOB)或行长度较大时:

为什么加 LIMIT 1 有时并不能加速慢查询

因为 LIMIT 是结果截断,不是执行剪枝:

EXPLAIN SELECT * FROM orders WHERE user_id = 123 ORDER BY created_at DESC LIMIT 1;

真正影响读取效率的,从来不是 SQL 写法表面的简洁,而是数据如何组织、索引如何设计、以及每一行背后的页加载与过滤时机。很多“慢查询”优化,本质是把 “让 MySQL 少读几个页” 变

成可落地的动作,而不是调参数或改写 SQL 本身。