mysql 索引异常:
mysql 索引异常:
1 通常的异常情况为,使用错索引,导致慢查询。
2 为什么会使用错索引呢?
因为在执行 sql 之前,优化器会 分析语句,选择不同的索引 导致不同的 扫描行数, 排序等操作,因此存在选错索引的情 况。
优化器会判断使用这个索引需要扫描多少行的数据。
3 不同的索引会有不同的基数:就是这个索引被多少不同的数据引用(索引的这一列大概有多少数据。) 计算方法即使,随机 选取几个数据页,计算出数据量的平均值,然后乘以页数。
4 在 MySQL 中,有两种存储索引统计的方式,可以通过设置参数 innodb_stats_persistent 的值来选择:
设置为 on 的时候,表示统计信息会持久化存储。这时,默认的 N 是 20,M 是 10。
设置为 off 的时候,表示统计信息只存储在内存中。这时,默认的 N 是 8,M 是 16。
5 应对索引异常的情况,可以采取下面三种方式应对:
5.1 强制使用某个索引。
5.2 修改语句引导mysql使用期望的索引。
5.3 删除或者新建索引。
6 analyze table t 命令,可以用来重新统计索引信息。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)