侧边栏壁纸
博主头像
996worker

祇園精舎の鐘の聲, 諸行無常の響き有り。

  • 累计撰写 174 篇文章
  • 累计创建 45 个标签
  • 累计收到 8 条评论

目 录CONTENT

文章目录

How to make the Index in MySQL become invalid? MySQL索引失效

996worker
2022-05-19 / 0 评论 / 0 点赞 / 37 阅读 / 867 字
温馨提示:
本文最后更新于 2022-06-26,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

凡例

  1. Use != or <>
SELECT * FROM `user` WHERE `name` != 'namename'; 

此时会进行全表扫描导致索引失效.

  1. 搜索时输入和表字段不一致(隐式类型转换)
SELECT * FROM `user` WHERE height= 175; 

如果height在表中存储的是varchar, 在查询过程中存在隐式类型转换, 导致全表扫描;

  1. 搜索的索引字段包了个函数, 不会索引
SELECT * FROM `user` WHERE DATE(create_time) = '2022-09-03';
  1. 对索引字段使用运算符, 不会索引
SELECT * FROM `user` WHERE age - 2 = 20;

运算符包括加减乘除

  1. OR连接不同字段时, 索引失效 (OR连接同字段, 不会失效)
SELECT * FROM `user` WHERE `name` = 'zhangsan' OR height = '195';
  1. NOT IN, NOT EXIST 不走索引
SELECT s.* FROM `user` s WHERE NOT EXISTS (SELECT * FROM `user` u WHERE u.name = s.`name` AND u.`name` = 'namename')

SELECT * FROM `user` WHERE `name` NOT IN ('namename');
  1. 通配符在头部的模糊搜索不走索引
SELECT * FROM `user` WHERE `name` LIKE '%冰';
  1. IS NULL不走索引, IS NOT NULL走索引
SELECT * FROM `user` WHERE address IS NULL

启示: 如果非必须, 不要让记录里有null, 不然可能有索引失效的问题.

0

评论区