Mysql索引失效场景集合

本文总结了Mysql中索引失效的一些常见场景,包括:索引列上有计算或函数操作、字段类型不匹配、like操作符左侧包含、列对比及与、not in和not exists等。通过实例展示,帮助理解为何这些情况下索引无法被有效利用,并提供了优化建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们经常会遇到两种情况:

  • 明明在某个字段上加了索引,但实际上并没有生效。
  • 索引有时候生效了,有时候没有生效。

索引失效的场景汇总如下:

  1. 使用select *
  2. 索引列上有计算操作
  3. 索引列上有函数操作
  4. 字段类型不同
  5. like左边包含%
  6. 进行索引的列对比
  7. not innot exist

准备数据

CREATE TABLE example  
(  
    id      int NOT NULL AUTO_INCREMENT,  
    code    varchar(20) DEFAULT NULL,  
    age     int         DEFAULT 0,  
    name    varchar(30) DEFAULT NULL,  
    height  int         DEFAULT 0,  
    PRIMARY KEY (id),  
    KEY idx_code_age_name (code, age, name),  
    KEY idx_height (height)  
); 

INSERT INTO example (id, code, age, name, height, address)  
VALUES (1, '10', 21, '张三', 175, '北京');  
INSERT INTO example(id, code, age, name, height, address)  
VALUES (2, '11', 18, '李四', 173, '上海');  
INSERT INTO example (id, code, age, name, height, address)  
VALUES (3, '12', 23, '王武', 174, '广州');  
INSERT INTO example (id, code, age, name, height, address)  
VALUES (4, '13', 22, '马六', 154, '重庆');

创建了三个索引

  • id:数据库的主键
  • idx_code_age_name:由code、age和name三个字段组成的联合索引
  • idx_height:普通索引

查看执行计划,可以使用explain关键字,例如:

explain select * from example where id=1;

执行结果:
image
从图中可以看出,由于id字段是主键,该SQL语句用到了主键索引

使用select *

案例SQL

explain  
select * from example where name='苏三'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值