MySQL 中的索引下推功能

news2024/11/25 20:01:48

看到索引,应该大家都可以联想到这个是和查询效率有关系的,既然有这个功能,那么那句古话说的好啊:存在即合理。那么这个就是说有了这个功能,可以提升查询效率。

什么是索引下推

我们先有一个大概的理解:在 MySQL 中,索引下推(Index Condition Pushdown,简称 ICP)是一种优化技术,就是为了提高有索引表的查询性能

索引下推主要的目的是:在索引扫描过程中尽可能减少回表操作(所谓回表:是指索引中返回数据行到服务器层进行进一步过滤),从而提高查询效率。

原理

没有索引下推时

在没有索引下推的情况下,存储引擎通过索引检索到数据行后,会将数据行返回给服务器层,服务器层再根据 WHERE 条件中的其他条件(非索引条件)进行过滤判断。

有索引下推时

而有了索引下推,存储引擎在检索索引的过程中,就可以根据 WHERE 条件中的其他条件对索引中包含的数据进行判断过滤,只有符合条件的数据行才会被返回给服务器层。这样可以减少存储引擎返回给服务器层的数据行数,以及服务器层后续进行过滤判断的工作量。

这里我们看下存储引擎层和服务层的区别:
服务层和存储引擎层

看下这个图之后,应该大家都可以理解了,执行顺序是:
调用逻辑
总结一下哈:索引下推其实就是说,将过滤的行为传到了存储引擎层中,先在存储引擎层处理一遍,然后再返回给服务层。

为啥我感觉这个应该是理所当然的事情啊,好在这个功能现在已经是具备了。

使用场景示例

假设有一个表 users,这里我建了一个 age 和 city 的组合索引,其结构如下:

CREATE TABLE users (  
    id INT PRIMARY KEY,  
    name VARCHAR(100),  
    age INT,  
    city VARCHAR(100),  
    INDEX idx_age_city (age, city)  
);

如果执行以下查询:

SELECT * FROM users WHERE age BETWEEN 20 AND 30 AND city = 'New York';

在没有索引下推的情况下,MySQL 会扫描 idx_age_city 索引,找到所有 age 在 20 到 30 之间的记录,然后将这些记录返回给服务器层,服务器层再对这些记录进行 city = 'New York' 的过滤。

而在启用了索引下推的情况下,MySQL 会在存储引擎层就进行 city = 'New York' 的过滤,只有满足 age BETWEEN 20 AND 30city = 'New York' 的记录才会被返回给服务器层。

如何判断是否使用了索引下推

要确认查询是否使用了索引下推,可以使用 EXPLAIN 语句来查看查询的执行计划。在执行计划中,如果使用了索引下推,会在 Extra 列中看到 Using index condition

EXPLAIN SELECT * FROM users WHERE age BETWEEN 20 AND 30 AND city = 'New York';

如果执行计划中的 Extra 列显示 Using index condition,则说明该查询使用了索引下推优化。

索引下推带来的好处

  • 提高查询性能
    • 减少了存储引擎和服务器层之间的数据传输量,尤其是在表数据量很大、WHERE 条件比较复杂的情况下,性能提升效果更为明显。
    • 降低了服务器层的 CPU 开销,因为服务器层需要处理的数据行数减少了。
  • 优化复杂查询
    • 对于多表连接查询,如果连接列上有索引并且可以使用索引下推,也能提高连接查询的性能。

注意事项

索引下推是 MySQL 5.6 及以上版本引入的功能,因此在较低版本的 MySQL 中无法使用。

索引下推并不能替代所有情况下的回表操作,但对于某些查询模式,它可以显著减少回表操作的次数,从而提高查询性能。

索引下推与覆盖索引(covering index)不同,覆盖索引是指索引包含了查询所需的所有列,从而避免了回表操作。索引下推则是在索引扫描过程中进行部分条件的过滤,以减少回表操作的次数。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2239750.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

重拾CSS,前端样式精读-媒体查询

前言 本文收录于CSS系列文章中,欢迎阅读指正 说到媒体查询,大家首先想到的可能是有关响应式的知识点,除此之外,它还可以用于条件加载资源,字体大小,图像和视频的优化,用户界面调整等等方面&am…

物理设备命名规则(Linux网络服务器 15)

Linux系统中的一切都是文件,硬件设备也不例外。既然都是文件,就必须有文件名称。系统内核中udev设备管理器会自动把硬件名称规范化起来,目的是让用户通过设备文件的名字可以大致了解设备属性以及分区信息。这对于陌生的设备来说特别方便。另外…

NVIDIA NIM 开发者指南:入门

NVIDIA NIM 开发者指南:入门 NVIDIA 开发者计划 想要了解有关 NIM 的更多信息?加入 NVIDIA 开发者计划,即可免费访问任何基础设施云、数据中心或个人工作站上最多 16 个 GPU 上的自托管 NVIDIA NIM 和微服务。 加入免费的 NVIDIA 开发者计…

猿创征文|Inscode桌面IDE:打造高效开发新体验

猿创征文|Inscode桌面IDE:打造高效开发新体验 引言 在当今快速发展的软件开发领域,一个高效、易用的集成开发环境(IDE)是每个开发者必不可少的工具。Inscode 桌面 IDE 作为一款新兴的开发工具,凭借其强大…

力扣 LeetCode 142. 环形链表II(Day2:链表)

解题思路&#xff1a; 使用set判断是否重复添加&#xff0c;如果set加入不进去证明之前到达过该节点&#xff0c;有环 public class Solution {public ListNode detectCycle(ListNode head) {Set<ListNode> set new HashSet<>();ListNode cur head;while (cur …

激活函数解析:神经网络背后的“驱动力”

神经网络中的激活函数&#xff08;Activation Function&#xff09;是其运作的核心组件之一&#xff0c;它们决定了神经元如何根据输入信号进行“激活”&#xff0c;进而影响整个模型的表现。理解激活函数的工作原理对于设计和优化神经网络至关重要。本篇博客将深入浅出地介绍各…

基于表格滚动截屏(表格全部展开,没有滚动条)

import html2canvasPro from html2canvas // 截图&#xff0c;平辅表格 async function resetAgSize() {const allColumns gridApi.value.getColumns()let totalColumnWidth 0let totalColumnHeight 0// 遍历每一个行节点gridApi.value.forEachNode((rowNode) > {totalCo…

vs2015QT项目添加多语言翻译总结

一、简介 当软件有国际化的需求时&#xff0c;就需要多语言翻译功能&#xff0c;最常见的语言就是支持中文和英语&#xff0c;本文介绍在vs2015QT环境下&#xff0c;进行国际化翻译的具体流程。 二、多语言翻译实现流程 1.底层实现原理介绍 QT写的客户端软件&#xff0c;能…

wireshark演进之路——从GTK到Qt

Wireshark 自 1998 年诞生至今&#xff0c;已有超过26年的历史了。它最早由 Gerald Combs 创建&#xff0c;最初名为 Ethereal。2006 年&#xff0c;Ethereal 更名为 Wireshark&#xff0c;并继续发展成了全球领先且人尽皆知的网络协议分析工具&#xff0c;其GUI演变就是其中非…

哈希表的实现--C++

文章目录 一、哈希概念1.1、直接定址法1.2、哈希冲突1.3、负载因子1.4、将关键字转为整数1.5、哈希函数1.5.1、除法散列法/除留余数法1.5.2、乘法散列法1.5.3、全域散列法1.5.4、其他方法 二、处理哈希冲突2.1、开放定址法2.1.1、线性探测2.1.2、二次探测2.1.3、双重散列2.1.4、…

Python学习从0到1 day26 第三阶段 Spark ② 数据计算Ⅰ

人总是会执着于失去的&#xff0c;而又不珍惜现在所拥有的 —— 24.11.9 一、map方法 PySpark的数据计算&#xff0c;都是基于RDD对象来进行的&#xff0c;采用依赖进行&#xff0c;RDD对象内置丰富的成员方法&#xff08;算子&#xff09; map算子 功能&#xff1a;map算子…

D67【python 接口自动化学习】- python基础之数据库

day67 Python操作MySQL基础使用 学习日期&#xff1a;20241113 学习目标&#xff1a;MySQL数据库-- 136 Python操作MySQL基础使用 学习笔记&#xff1a; pymysql 创建MySQL的数据库链接 执行sql语句 总结 Python中使用第三方库&#xff1a;pymysql来操作MySQL&#xff0c;…

Linux驱动开发基础——Hello驱动程序(一)

目录 一、Hello驱动 一、Hello驱动 我们选用的内核都是 4.x 版本&#xff0c;操作都是类似的&#xff1a; 1.1、APP 打开的文件在内核中如何表示 open函数原型&#xff1a; int open(const char *pathname, int flags, mode_t mode); 仔细看函数的参数&#xff0c;再对比看 内…

2.初始sui move

vscode安装move插件 查看sui 客户端版本号 sui client --version 创建新项目 sui move new <项目名> sui move new hello_world 项目目录结构&#xff1a; hello_world ├── Move.toml ├── sources │ └── hello_world.move └── tests└── hello_world…

学习日志009--面向对象的编程

一、面向对象 面向对象编程&#xff08;Object-Oriented Programming&#xff0c;简称OOP&#xff09;是一种编程范式&#xff0c;它使用“对象”来设计应用程序和计算机程序。它利用了抽象、封装、继承和多态这些概念。 一、面向对象编程的核心概念 封装&#xff08;Encaps…

Redis8:商户查询缓存2

欢迎来到“雪碧聊技术”CSDN博客&#xff01; 在这里&#xff0c;您将踏入一个专注于Java开发技术的知识殿堂。无论您是Java编程的初学者&#xff0c;还是具有一定经验的开发者&#xff0c;相信我的博客都能为您提供宝贵的学习资源和实用技巧。作为您的技术向导&#xff0c;我将…

在 WPF 中,如何实现数据的双向绑定?

在 WPF 中&#xff0c;数据绑定是一个非常重要的特性&#xff0c;它允许 UI 与数据源之间自动同步。双向绑定是一种常见的绑定方式&#xff0c;当数据源更新时&#xff0c;UI 会自动更新&#xff1b;同样&#xff0c;当 UI 中的元素&#xff08;如文本框&#xff09;发生改变时…

DAY6 线程

作业1&#xff1a; 多线程实现文件拷贝&#xff0c;线程1拷贝一半&#xff0c;线程2拷贝另一半&#xff0c;主线程回收子线程资源。 代码&#xff1a; #include <myhead.h> sem_t sem1; void *copy1()//子线程1函数 拷贝前一半内容 {int fd1open("./1.txt",O…

# filezilla连接 虚拟机ubuntu系统出错“尝试连接 ECONNREFUSED - 连接被服务器拒绝, 失败,无法连接服务器”解决方案

filezilla连接 虚拟机ubuntu系统出错“尝试连接 ECONNREFUSED - 连接被服务器拒绝&#xff0c; 失败&#xff0c;无法连接服务器”解决方案 一、问题描述&#xff1a; 当我们用filezilla客户端 连接 虚拟机ubuntu系统时&#xff0c;报错“尝试连接 ECONNREFUSED - 连接被服务…

网安数学基础-同余关系

文章目录 参考等价关系实例 同余同余和等价同余的运算 乘法逆元一次同余方程消去律 剩余类中国剩余定理欧拉函数欧拉定理 费马小定理 参考 【一口气学完】密码学的数学基础2&#xff0c;《同余关系》&#xff0c;一小时学完 等价关系 三角形里的全等关系 等价关系定义 下面这…