每日八股文

Q:MySQL中的回表是什么?

回表是二级索引的B+树进行查找的一个操作,二级索引存储索引和主键值 ,聚簇索引存储完整数据,当对二级索引的数据进行查询是,查到他的主键值,在通过主键值,查到对应的数值,用一个形象的比喻来说,相当于查字典时候,你通过拼音(二级索引)查到相应的页码(聚簇索引),在通过页面找到对应页面,获得这个词语的完整解释. 简单来说就是二级索引不够用,需要再借助一次主键索引

举一个简单的例子 select* from user where age=20;由于二级索引存储的是索引和主键值,即age 和 id,没有name,所以先通过二级索引拿到主键值2,在通过主键值2去聚簇索引拿到name

Q:如何避免回表,减少回表?

A:(1)覆盖索引,比如上方的例子,可以把索引值改成(name,age),那么索引值是name,age,主键值是id,索引的叶子节点存储了name ,age ,id,直接就可以查到数据,不用回表

(2)索引下移

MysSQL5.6之后引入的,例如 select*from user where age = 20 and name like "张";之前的mysql是先拿到age=20数据,然后全部回表拿到完整数据,再在server层进行过滤

5.6之后,可以直接通过like在引擎层过滤一遍,不符合条件的直接跳过不回表,减少了大量的回表

(3)减少select *的使用

Q:回表的性能代价?

A:通过二级索引拿到的主键值不是连续的,比如拿到age=20,存储age=20的数据很多,而且他不是顺序存储,进行查询时,需要定位到不同的页面,同时带来大量的I/O

顺序I/O可以预读磁盘,一次可以读大量的连续数据,随机I/O每次都要重新寻址,磁盘来回转,很慢,导致性能大幅度下降

Q:怎么判断一个查询有没有回表?

执行Explain 看extra,如果显示的是Using index ,则说明覆盖索引,不需要再次回表,如果无Using index ,则需要回表,如果遇到type这种情况,有时候也需要回表

Q:在Mysql中建索引需要哪些注意事项?

A:1:索引不是越多越好,会占用空间,索引也是需要维护的,索引太多,代价比较大

2:大量重复的字段不要建立索引,例如性别,效率不高

3:长字段不要建立索引,例如text,longtext

4:表的修改频率远远高于查询频率的时候,不建立索引

5:频繁出现在where后面的字段,要建立索引,

6:order by, group by,distint 后面出现的字段,建立索引,因为涉及到排序,分组,去重,而所以是有序的,可以加快速度

相关推荐
Flittly16 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了16 小时前
Java 生成二维码解决方案
java·后端
人活一口气20 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP1 天前
Vibe Coding -- 完整项目案例实操
java
荣码1 天前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing1 天前
Google第三方授权登录
java·后端·程序员
明月光8181 天前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯1 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路1 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java