当前位置: 首页 > news >正文

Mysql——索引下推

MySQL的索引下推(Index Condition Pushdown, ICP)是一种查询优化技术,它允许MySQL在存储引擎层执行部分WHERE子句中的过滤条件,而非全部在MySQL服务器层执行。这使得在扫描索引过程中就可以剔除不满足条件的记录,从而减少不必要的数据读取和回表操作,提高查询性能。

索引下推例子
假设有一个销售订单表orders,其上有如下结构及索引:

CREATE TABLE `orders` (`order_id` INT PRIMARY KEY,`customer_id` INT,`product_id` INT,`order_date` DATE,INDEX idx_customer_product (`customer_id`, `product_id`)
);

现在有一个查询:

SELECT * FROM orders
WHERE customer_id = 123 AND product_id = 456 AND order_date > '2020-01-01';

在没有启用索引下推的情况下,MySQL可能会首先使用复合索引idx_customer_product找到所有customer_id = 123product_id = 456的记录,然后对于索引扫描的结果,逐行回表查询对应的完整行数据,再在MySQL服务器层检查order_date > '2020-01-01'这个条件。

然而,启用索引下推后,MySQL会将order_date > '2020-01-01'这个条件下推到存储引擎层,在扫描idx_customer_product索引时,不仅能匹配customer_idproduct_id,同时也会在索引内直接判断order_date是否大于’2020-01-01’,只有当索引中的这三个条件都满足时,才会真正回表读取完整的行数据。

这种优化意味着MySQL能够在访问实际数据页之前,提前在索引内部完成更多条件的过滤,极大地提升了查询效率。

MySQL的索引下推(Index Condition Pushdown,简称ICP)是一项优化查询性能的技术,它是MySQL从5.6版本开始引入的一项重要特性。在传统的查询执行流程中,MySQL服务器层可能需要先根据索引检索到相关的记录主键,然后再到存储引擎层根据这些主键值获取完整的行数据,最后在服务器层对行数据应用WHERE子句中的其他过滤条件。

索引下推优化了这个过程,它允许MySQL服务器在生成执行计划时,将那些可以在索引中直接计算或过滤的WHERE条件下推到存储引擎层进行执行。这意味着存储引擎在遍历索引的过程中,不仅可以利用索引快速定位记录,而且可以在读取索引的同时就完成一部分WHERE条件的判断,只取出那些真正满足所有条件的行数据,而不是先返回所有引用主键的记录,再由服务器层进一步筛选。

例如,在一个带有多个列的索引中,即使查询条件包含了索引列和非索引列,ICP也能发挥作用,存储引擎可以直接在索引内部进行多列条件的初步筛选,减少不必要的回表操作(即减少访问实际数据页的次数),从而降低IO成本,提高查询性能。

总结来说,MySQL索引下推的作用在于:
1. 减少存储引擎访问基表的次数。
2. 减少MySQL服务器层与存储引擎层之间的数据传输量。
3. 提高了SQL查询的执行效率,特别是在涉及大量数据过滤时效果尤为显著。

http://www.lryc.cn/news/325470.html

相关文章:

  • Springboot项目之mybatis-plus多容器分布式部署id重复问题之源码解析
  • 微信答题小程序云开发--实现云函数上传题目图片 base64功能
  • 学会Sass的高级用法,减少样式冗余
  • 【Java初阶(五)】类和对象
  • AWTK-MODBUS 服务器
  • JavaScript快速入门笔记之一(基本概念)
  • 前端学习之css基本网格布局
  • [网鼎杯2018]Unfinish 两种方法 -----不会编程的崽
  • 安防监控视频汇聚平台EasyCVR在银河麒麟V10系统中的启动异常及解决方法
  • 了解云原生
  • 【go从入门到精通】for和for range的区别
  • 【C语言】【Leetcode】88. 合并两个有序数组
  • DMA控制器
  • SQLiteC/C++接口详细介绍sqlite3_stmt类(十)
  • Android 生成Excel文件保存到本地
  • Hive-技术补充-ANTLR语法编写
  • 6.使用个人用户登录域控的成员服务器,如何防止个人用户账号的用户策略生效?
  • 模拟算法
  • 【数据结构刷题专题】—— 二叉树
  • 基于AWS云服务构建智能家居系统的最佳实践
  • Java零基础-集合:Set接口
  • 数据结构与算法-排序算法
  • SpringBoot 文件上传(三)
  • web渗透测试漏洞流程:红队目标信息收集之资产搜索引擎收集
  • UI自动化_id 元素定位
  • 华为OD技术面算法题整理
  • vmware虚拟机下ubuntu扩大磁盘容量
  • 秋招打卡算法题第一天
  • BC98 序列中删除指定数字
  • 基于Java的学生体质健康管理系统的设计与实现(论文+源码)_kaic