铁马冰河2000

导航

统计

MySQL面试题

  1. MySQL 索引使用有哪些注意事项呢?

    可以从两个维度回答这个问题:索引哪些情况会失效,索引不适合哪些场景

  • 索引哪些情况会失效

查询条件包含or,会导致索引失效。
隐式类型转换,会导致索引失效,例如age字段类型是int,我们where age = “1”,这样就会触发隐式类型转换。
like通配符会导致索引失效。注意:"ABC%“会走range索引,”%ABC"索引才会失效。
联合索引,查询时的条件列不是联合索引中的第一个列,索引失效。
对索引字段进行函数运算。
对索引列运算(如,+、-、*、/),索引失效。
索引字段上使用(!= 或者 < >,not in)时,会导致索引失效。
索引字段上使用is null, is not null,可能导致索引失效。
相join的两个表的字符编码不同,不能命中索引,会导致笛卡尔积的循环计算
mysql估计使用全表扫描要比使用索引快,则不使用索引。

  • 索引不适合哪些场景

数据量少的不适合加索引
更新比较频繁的也不适合加索引
离散性低的字段不适合加索引(如性别)

posted on   铁马冰河2000  阅读(37)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示