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助手
相关推荐
TheRouter几秒前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现Omics Pro8 分钟前
首个!外源天然产物综合性代谢图谱voidmort16 分钟前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想biter down1 小时前
基于 Pywinauto 的 QQ 音乐 GUI 自动化测试实践人道领域1 小时前
【LeetCode刷题日记】669.修剪二叉搜索树JAVA面经实录9171 小时前
Hibernate面试题库迷枫7122 小时前
DM8 目录结构与常用排查入口梳理EntyIU2 小时前
mineru从安装部署到测试使用完整指南Mr.Daozhi3 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)安替-AnTi3 小时前
厚朴 APK 搜索接口分析