
MySQL 索引使用有哪些注意事项呢?
可以从三个维度回答这个问题:索引哪些情况会失效,索引不适合哪些场景,索引规则
索引哪些情况会失效
1、查询条件包含 or,可能导致索引失效
2、如何字段类型是字符串,where 时一定用引号括起来,否则索引失效
3、like 通配符可能导致索引失效。
4、联合索引,查询时的条件列不是联合索引中的第一个列,索引失效。
5、在索引列上使用 MySQL 的内置函数,索引失效。
6、对索引列运算(如,+、-、*、/),索引失效。
7、索引学段上使用(!=或者<>,not in)时,可能会导致索引失效。
8、索引字段上使用 is null,is not null,可能导致索引失效。
9、左连接查询或者右连接查询查询关联的字段编码格式不一样,可能导致索引失效。
10、MySQL 估计使用全表扫描要比使用索引快,则不使用索引。
索引不适合哪些场景
1、数据量少的不适合加索引
2、更新比较频繁的也不适合加索引
3、区分度低的字段不适合加索引(如性别)
索引的一些潜规则
1、覆盖索引
2、回表
3、索引数据结构(B+树)
4、最左前缀原则
5、-索引下推
MySQL 遇到过死锁问题吗,你是如何解决的?
我排查死锁的一般步骤是酱紫的:
1、查看死锁日志 show engine innodb status;