MySQL 8.0 并行扫描仅对无索引全表扫描的InnoDB大表查询生效,需显式配置innodb_parallel_read_threads>0且用EXPLAIN FORMAT=TREE验证,不适用于聚合、LIMIT、索引查找等场景。MySQL 8.0 并行扫描只对特定引擎和查询生效并行扫描不是"所有 SELECT 都自动变快",它只在 InnoDB 表上、配合 EXPLAIN FORMAT=TREE 能看到 Parallel scan 提示的场景才真正启用。最常见触发条件是:全表扫描(无有效索引)、WHERE 条件简单(如 WHERE id > 1000)、且查询涉及大量数据(通常 > 数百万行)。MyISAM、Memory、分区表(即使底层是 InnoDB)都不支持;带 LIMIT、DISTINCT、GROUP BY、子查询或窗口函数的语句也大概率退回到单线程。SELECT * FROM huge_table WHERE status = 1 → 可能并行(若 status 无索引)SELECT COUNT(*) FROM huge_table → 不并行(聚合强制单线程)SELECT * FROM huge_table WHERE id IN (1,2,3) → 不并行(走索引,不触发扫描)必须手动开启并行度参数,且默认是关闭的MySQL 8.0 默认关闭并行扫描,靠 innodb_parallel_read_threads 控制线程数,值为 0 表示禁用。它不是全局并发开关,而是每个满足条件的查询最多可使用的后台线程数(上限 4,设为 1 就等于没开)。这个参数不能动态 SET GLOBAL 永久生效------它只在会话级临时有效,且仅对后续新执行的查询起作用;服务重启后恢复为 0。生产环境想长期使用,得写进配置文件 my.cnf 的 [mysqld] 段里。临时启用:SET SESSION innodb_parallel_read_threads = 4;配置文件写法:innodb_parallel_read_threads = 4值设太高反而可能拖慢:超过 CPU 核心数或 I/O 带宽时,线程争抢导致延迟上升EXPLAIN 看不到并行?先确认 FORMAT 和执行计划层级普通 EXPLAIN 输出里完全不会提"parallel",必须用 EXPLAIN FORMAT=TREE 才能看到是否触发。而且只有当扫描成为执行计划最外层节点(比如没被嵌套在派生表或物化临时表里)时,才会显示 Parallel scan。 RedClaw 百度推出的手机端万能AI Agent助手
相关推荐
m0_493934532 小时前
Redis如何批量移动标签_利用SMOVE指令在Set之间转移数据Jul1en_2 小时前
【Redis】Set类型、命令及应用场景Shorasul2 小时前
如何用 some 检测数组中是否存在至少一个满足条件的项CappuccinoRose2 小时前
关系数据库标准语言(SQL)- 软考备战(三十一)2402_854808372 小时前
html如何修改备注xier_ran2 小时前
【C++】static 关键字与 const 关键字的作用2401_835956812 小时前
Tailwind CSS如何实现文字装饰线_使用decoration系列类丰富CSS文字qq_334563552 小时前
如何在MongoDB中实现连表查询_group与累计求和操作木泽八2 小时前
分布式系统架构模式精讲:CQRS、Saga与数据库选型完全指南