什么是回表,怎么解决?

mysql 文章 2022-07-15 14:23 1015 0 全屏看文

AI助手支持GPT4.0

表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

-EOF-

AI助手支持GPT4.0


国内超级便宜服务器

摸鱼人热门新闻聚合

钻级赞助商 我要加入

开发者在线工具

第三方支付技术请加QQ群

相关文章
The MySQL server is running with the --read-only option so it cannot execute this statement
mac(m1)配置my.cnf
牛客SQL刷题第三趴——SQL大厂面试真题
重新学习数据库(1)
druid 曝出No operations allowed after connection closed 解决方案
随便看看
微信支付小程序支付,c#调起统一下单,appid与openid不匹配 710
App纯签约other? 472
小程序用户反馈入口,存在用户多次恶意反馈(15分钟内恶意反馈2000次+) 669
长链接转短链接失败了,今天,返回成功,但是依旧是长链接? 666
qq小程序和微信小程序的基建怎么差这么多? 521
小程序通过 发送给朋友 分享,打开时提示不支持打开非业务域名? 650
商品发布成功,商品图片无法显示 411
小程序跳转分享页? 457
如何拉起其他开发者开发的小程序呢? 518
请教一下,高端机,中端机,低端机如何区分?想针对低端机做性能优化 443