如何优化 MySQL 索引以提高查询性能?
MySQL 索引优化 完整总结(面试 / 实操通用,精简好背)
一、合理创建索引
高频查询字段建索引
WHERE、JOIN、ORDER BY、GROUP BY 字段优先建立索引。
选择性高的字段建索引
区分度越高(如手机号、身份证)索引效果越好;
性别、状态等低基数字段不适合单独建索引。
优先使用复合索引
多字段查询时,建立复合索引,遵循最左前缀原则。
二、遵循复合索引设计原则
等值条件放前面,范围条件放后面(= > in > like 前缀 > range)。
频繁查询字段前置,避免索引断裂。
避免冗余索引,合并重复、重叠索引。
三、避免索引失效(关键优化)
索引列不做函数、运算、类型转换。
LIKE 禁止左模糊 %xxx。
减少 !=、<>、not in、is not null。
OR 两侧字段都要有索引,否则全失效。
杜绝隐式类型转换(字符串字段加引号)。
四、优化索引字段设计
字段长度尽量小
用 tinyint、varchar (短长度),减少索引占用空间。
主键建议使用自增 int/bigint,不要用长字符串、UUID。
优先覆盖索引
查询字段全部包含在索引中,避免回表(Extra:Using index)。
五、SQL 语句优化
禁止 select *,只查需要字段,配合覆盖索引。
分页深分页优化:避免 limit 100000,10。
减少关联查询,JOIN 字段必须建立索引。
合理限制结果集,避免大结果集扫描。
六、维护与优化
定期使用 ANALYZE TABLE 更新索引统计信息。
清理无用、长期不使用的索引,减少写入开销。
大表避免频繁新增 / 删除索引,低峰期维护。
读写分离:读走索引优化,写减少索引数量。
七、限制索引数量
索引
提升查询、降低写入;
表写入频繁时,严控索引数量,防止插入 / 更新变慢。
极简背诵版
高频筛选、排序、联表字段建索引;
复合索引遵守最左前缀,等值在前、范围在后;
杜绝索引列运算、左模糊、隐式转换防止失效;
设计覆盖索引,减少回表,禁用 select *;
精简索引、删除冗余,平衡查询与写入性能。
“如何优化 MySQL 索引以提高查询性能?” 的相关文章
一、iPhone如何快速整理你的相册当手机中的照片或视频太多,管理变得越来越麻烦时,我们可以利用相册中自带的功能对照片进行分类,下面看看iPhone如何快速整理相册。1、打开手机中的【照片】,点击底部导航栏中的【相簿】按钮。在页面左上方点击【+】号图标,在弹出的列表中选择【新建相簿】,如下图所示。图...
一、清理无用数据(最快见效)删除重复照片、模糊截图、过期视频、无用录屏,这类文件占用空间最大。清理软件缓存、垃圾文件、过期安装包、压缩包。删掉不再需要的聊天记录、旧文件、离线缓存内容。二、本地备份,释放云端空间用电脑有线连接手机,把照片、视频、大文件批量保存到电脑硬盘。重要资料存电脑本地,不用全部上...
下面分 Windows 和 Mac,把系统自带云同步和 ** 常见第三方云盘(OneDrive/iCloud/ 百度网盘)** 都一次性关掉,适合你要 “改记录不被覆盖” 的场景。Windows 电脑:关闭所有云同步1. 先关 OneDrive(最关键)右下角任务栏,找到蓝色云朵 OneDrive...
关闭云同步后,防止数据自动恢复、被云端覆盖的方法一、彻底切断云端连接全程断开网络修改文件、记录期间,关闭电脑和手机的 WiFi、移动数据。离线状态下,设备无法连接云端,就不会自动下载旧数据、覆盖修改内容。退出云端账号电脑退出 OneDrive、百度网盘账号;手机退出品牌云服务、iCloud 账号。账...
下面按开源主流、云厂商、端侧 / 鸿蒙、轻量科研四类,直接给可落地、口碑好的 AI 算力调度工具,附核心算法、适用场景和关键能力。一、通用开源调度框架(K8s 生态,工业级)1. Volcano(CNCF,字节 / 华为主导)核心算法:Gang 调度、DRF(主导资源公平)、Bin-packing、...
智能算力调度算法的应用场景一、人工智能领域大模型训练与推理自动分配 CPU、GPU、NPU 资源,合理调度训练任务、文本 / 图片 AI 推理任务,避免算力拥挤,提升运行速度。端侧 AI 应用手机、平板、智能设备的 AI 拍照、语音助手、人脸识别,依靠智能调度合理分配本地算力,降低耗电、减少卡顿。二...