在我们常规做数据库开发时,都会为每个表设置适合它的索引来加快数据库的搜索效率。
但有了索引也不是说就万事大吉,所有查询都没问题。像我们使用
但也可能因为你使用错误的SQL语句而无法使用。其中有以下几种,在使用sql查询时尽量避免。
select * from user where name <> '张三';
最左侧不使用%时也会使用索引(最左匹配),否则不使用索引。
select * from user where name like '%三%';
select * from user where name not in ('张三');
select * from user where name is not null;
select * from user where date(create_time) = '2021-02-03';
查询条件类型与字段类型不相符时,如下边例子,字段是字符串类型条件使用数值类型。
select * from user where name > 30;
包括(+、-、*、/)都会导致索引失效
select * from user where age + 2 = 30;
or导致索引失效是在特定情况下,并不是所有的or都会导致索引失效,如果or连接的是一个字段,那么就不会失效,反之索引失效。
select * from user where name = '张三' or age > 30;
即使完全符合索引生效的场景,考虑到实际数据量等原因,最终是否使用索引还要看MySQL优化器的判断。当然你也可以在sql语句中写明强制走某个索引。
这种情况概率极低,我也只遇到过一回,确定where条件使用了索引也执行了查询,但返回的数据结果与实际不相符。未能找到原因,后来只是把这个索引删除后重建就正常了。