到底什么情况下mysql innodb会发生回表操作

首页 / 常见问题 / 低代码开发 / 到底什么情况下mysql innodb会发生回表操作
作者:低代码工具 发布时间:2025-05-15 09:44 浏览量:5494
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

比如说你建立了一个A,B联合索引,你的sql语句是 select A,B from table where A=xxx, B=xxx你会发现你想要搜索的A,B从索引数据中已经存在了,压根不用拿到id到表数据中去查找,此时便不会回表,这种现象就叫做索引覆盖。

一、什么情况下mysql innodb会发生回表操作

比如说你建立了一个A,B联合索引,你的sql语句是 select A,B from table where A=xxx, B=xxx你会发现你想要搜索的A,B从索引数据中已经存在了,压根不用拿到id到表数据中去查找,此时便不会回表,这种现象就叫做索引覆盖。

现在你把语句改为了 select A,B,C from table where A=xxx, B=xxx,C毕竟不在索引数据中,拿不到,那只能先拿到id再导表数据文件中搜索,此时就是回表

避免回表:

  1. 用主键搜索
  2. 只查询被联合索引覆盖的字段

MySQL innodb的主键索引是簇集索引,也就是索引的叶子节点存的是整个单条记录的所有字段值,不是主键索引的就是非簇集索引,非簇集索引的叶子节点存的是主键字段的值。回表是什么意思?就是你执行一条sql语句,需要从两个b+索引中去取数据。举个例子:

表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建联合索引。但具体情况要具体分析,索引字段多了,存储和插入数据时的消耗会更大。这是个平衡问题。

延伸阅读:

二、Power BI是什么

Power BI(power business intelligence)是软件服务、应用和连接器的集合,它们协同工作以将相关数据来源转换为连贯的视觉逼真的交互式见解。 无论用户的数据是简单的 Excel 电子表格,还是基于云和本地混合数据仓库的集合,Power BI 都可让用户轻松地连接到数据源,直观看到(或发现)重要内容,与任何所希望的人进行共享。

Power BI 简单且快速,能够从 Excel 电子表格或本地数据库创建快速见解。 同时 Power BI 也可进行丰富的建模和实时分析,及自定义开发。 因此它既是用户的个人报表和可视化工具,还可用作组项目、部门或整个企业背后的分析和决策引擎。

最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

产品管理科目代码是什么?全面解析与未来趋势
03-18 11:27
服装管理代码到底是多少位?全面解析服装管理代码
03-18 11:27
建筑类工程管理代码到底是什么?全面解析来了!
03-18 11:27
建设工程管理代码到底有多少位?揭秘编码背后的秘密
03-18 11:27
资产管理项目代码是什么?全面解析与应用技巧
03-18 11:27
产品管理代码是什么?如何构建高效的代码体系?
03-18 11:27
媒介营销管理代码是什么?揭秘企业高效营销的智能中枢系统
03-18 11:27
产品管理的‘代码’到底是什么?揭秘高效管理的核心方法论与工具组合
03-18 11:27
如何高效解答产品管理中微信代码填写难题?
03-18 11:27

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科发路8号金融基地1栋5F5
  • 手机:137-1379-6908
  • 电话:0755-86660062
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2026. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
客服咨询热线1
0755-86660062
客服咨询热线2
137-1379-6908
申请预约演示
立即与行业专家交流