【MySQL-索引调优】08:模糊查询与索引

PS:给order表新增remark索引

sql 复制代码
CREATE INDEX idx_remark ON orders(remark);

现在orders表中存在idx_user_id(user_id),idx_user_status(user_id, status),idx_remark(remark)三个索引

8-1.后置%

运行:

sql 复制代码
EXPLAIN SELECT * FROM orders WHERE remark LIKE '71ae%';

结果为:

id select_type table partitions type possible_keys key key_len ref rows filtered Extra
1 SIMPLE orders range idx_remark idx_remark 1023 207 100 Using index condition

分析:

  • type = range :表示这是一个范围扫描。因为 LIKE '71ae%' 在索引上相当于一个范围条件:大于等于 '71ae' 且小于 '71af'(实际上是以 '71ae' 开头的所有字符串)。所以MySQL会用索引做范围查找
  • possible_keys = idx_remark :数据库识别到可以用 remark 的索引
  • key = idx_remark:实际使用的就是你刚建的索引
  • rows = 207:预估只需要扫描207行,全表扫描已经被优化掉了
  • filtered = 100:表示这207行全部符合条件
  • Extra = Using index condition :说明使用了 Index Condition Pushdown (ICP) 优化:过滤条件直接在索引层完成,而不是先取出数据再过滤,这进一步减少了回表的开销

8-2.中间%

运行:

sql 复制代码
EXPLAIN SELECT * FROM orders WHERE remark LIKE '%71ae%';

结果为:

id select_type table partitions type possible_keys key key_len ref rows filtered Extra
1 SIMPLE orders ALL 99520 11.11 Using where

分析:

LIKE '%71ae%',索引无法使用。在 MySQL 中,B+Tree 索引必须从左侧开始匹配

因为索引 idx_remark 的结构类似:

复制代码
71aa....
71ab....
71ac....
71ae....
71af....

如果查询:

复制代码
LIKE '71ae%'

数据库可以直接定位:

复制代码
71ae 开头的范围

但如果查询:

复制代码
LIKE '%71ae%'

数据库不知道

复制代码
71ae在字符串什么位置

总结:

  • LIKE 'abc%' → 可以使用索引
  • LIKE '%abc' → 无法使用索引
  • LIKE '%abc%' → 无法使用索引

8-3.真实系统如何解决%xxx%查询

  1. 方案1:全文索引

MySQL提供:

复制代码
FULLTEXT INDEX

适合:文章、评论、文本

  1. 方案2:搜索引擎

例如:Elasticsearch

适合:模糊搜索、关键词搜索

  1. 方案3:前缀搜索

系统设计时只允许:

复制代码
prefix search

例如:订单号、用户ID、编码

相关推荐
@小柯555m5 小时前
MySql(高级操作符--操作符混合运用)
数据库·sql·mysql
CDN3605 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库
bzmK1DTbd5 小时前
JDBC编程规范:PreparedStatement与事务管理
数据库·python·eclipse
卧室小白5 小时前
Redis-哨兵模式
数据库·redis·缓存
GottdesKrieges5 小时前
OceanBase恢复常见问题
java·数据库·oceanbase
卧室小白5 小时前
redis-配置
数据库·redis·缓存
techdashen6 小时前
从 51% CPU 占用到 SIMD 加速:Cloudflare 防火墙引擎的性能优化实录
性能优化
向風而行6 小时前
MySQL详解
数据库·mysql
草履虫君6 小时前
VMware 虚拟机网络性能优化指南:从 11 秒到 4 秒的完整调优实践
服务器·网络·经验分享·性能优化
belldeep7 小时前
本草纲目:如何应用 PostgreSQL 实现【中医药】主题数据库 ?
数据库·postgresql·本草纲目