百木园-与人分享,
就是让自己快乐。

什么是回表,怎么解决?

表tbl有a,b,c三个字段,其中a是主键,b上建了索引,
然后编写sql语句SELECT * FROM tbl WHERE a=1这样不会产生回表,因为所有的数据在a的索引树中均能找到

SELECT * FROM tbl WHERE b=1这样就会产生回表,因为where条件是b字段,那么会去b的索引树里查找数据,但b的索引里面只有a,b两个字段的值,没有c,那么这个查询为了取到c字段,就要取出主键a的值,然后去a的索引树去找c字段的数据。查了两个索引树,这就叫回表

索引覆盖就是查这个索引能查到你所需要的所有数据,不需要去另外的数据结构去查。其实就是不用回表。

怎么避免?不是必须的字段就不要出现在SELECT里面。或者b,c建联合索引。但具体情况要具体分析,索引字段多了,存储和插入数据时的消耗会更大。这是个平衡问题

 

原文:https://blog.csdn.net/qq_43410909/article/details/122437980

作者:crazyLL
说明:https://www.cnblogs.com/crazy-lc/
纯粹自己记录着玩的,来源于自己的想法或者互联网文章,侵删


来源:https://www.cnblogs.com/crazy-lc/p/16474311.html
本站部分图文来源于网络,如有侵权请联系删除。

未经允许不得转载:百木园 » 什么是回表,怎么解决?

相关推荐

  • 暂无文章