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在比较最合适的索引的依据

相关推荐
半桶水专家几秒前
MySQL CPU 飙高排查全流程指南
数据库·mysql·adb
qq_417695054 分钟前
用Python创建一个Discord聊天机器人
jvm·数据库·python
2401_874732534 分钟前
使用Scrapy框架构建分布式爬虫
jvm·数据库·python
老虎062715 分钟前
Spring mysql 网络接口( HTTP 方法与增删改查, Spring MVC Controller 接收参数的常用注解与参数传递方式)
mysql·spring·http
青槿吖17 分钟前
第二篇:Spring MVC进阶:注解、返回值与参数接收的花式玩法
java·开发语言·后端·mysql·spring·mvc·mybatis
运维 小白19 分钟前
4. 部署postgresql服务并监控postgresql
数据库·postgresql
qq_2468397527 分钟前
Redis lua本地调试环境配置
数据库·redis·lua
景川呀27 分钟前
Redis为什么快?
数据库·redis
十月南城27 分钟前
压测与成本优化实录——服务端、数据库与缓存协同优化与成本敏感点
数据库·缓存
L16247631 分钟前
linux中mdadm命令生产环境全流程实战总结
linux·运维·数据库