mysql对索引的选择简述

概述

在业务中经常会优化一些mysql的慢查询,通常都是使用explain去查看分析,检查扫描行数和索引的命中情况;

但是在具体索引的选择上,explain结果中并没有直接展示出来;

此时可以开启mysql的追踪优化器Trace功能;

mysql的追踪优化器Trace

sql 复制代码
SET session optimizer_trace="enabled=on"; -- 在当前session中打开追踪优化器
 
SET session optimizer_trace_max_mem_size = 1048576; -- 设置为1MB,根据实际情况调整

-- 和业务查询一起执行,查询mysql的索引比较
select * from INFORMATION_SCHEMA.OPTIMIZER_TRACE;

截图中可以看到mysql在比较最合适的索引的依据

相关推荐
IT摆渡者4 小时前
MySQL性能巡检脚本分析报告
数据库·mysql
Lyyaoo.5 小时前
Redis基础
数据库·redis·缓存
杨云龙UP6 小时前
ODA登录ODA Web管理界面时提示Password Expired的处理方法_20260423
linux·运维·服务器·数据库·oracle
解救女汉子6 小时前
SQL触发器如何获取触发源应用名_利用APP_NAME函数追踪
jvm·数据库·python
weixin_520649877 小时前
数据库函数
数据库
Bert.Cai8 小时前
MySQL LPAD()函数详解
数据库·mysql
OnlyEasyCode9 小时前
Navicat 任务自动备份指定数据库
数据库
if else9 小时前
Redis 哨兵集群部署方案
数据库·redis
yejqvow129 小时前
Pandas 高效实现组内跨行时间戳匹配与布尔标记
jvm·数据库·python
了不起的云计算V10 小时前
从DeepSeek V4适配看国产算力的三个拐点
数据库·人工智能