MySQL Index Condition Pushdown(ICP)的使用限制有哪些

技术MySQL Index Condition Pushdown(ICP)的使用限制有哪些小编给大家分享一下MySQL Index Condition Pushdown(ICP)的使用限制有哪些,希望大家阅读完这篇文章之

边肖想和大家分享一下使用MySQL索引条件下推(ICP)的限制。希望你看完这篇文章后有所收获。让我们一起讨论一下。

ICP(index condition pushdown)是mysql使用索引(辅助索引)元组和索引中筛选字段的where条件从表中提取数据记录的优化操作。ICP的思想是,在访问索引时,存储引擎检查索引中过滤字段的where条件(推送索引条件),如果索引元组中的数据不满足推送索引条件,则过滤掉数据记录。ICP (Optimizer)尽可能将索引条件的处理从服务器层下推到存储引擎层。存储引擎使用索引过滤无关数据,只将符合索引条件的数据返回给服务器层。也就是说,数据过滤尽量在存储引擎层进行,而不是将所有数据返回到服务器层,然后根据where条件进行过滤。

索引下推(ICP)是MySQL版本中的新功能,是存储引擎层通过索引过滤数据的优化方式。

答:当ICP关闭时,索引只是数据访问的一种访问方式,存储引擎通过索引回表得到的数据会传递到MySQL Server层进行where条件过滤。

b .当ICP开启时,如果某些where条件可以使用索引中的字段,MySQL server会将这部分下推到引擎层,通过索引过滤的where条件可以用于存储引擎层的数据过滤,而不是将所有通过索引访问的结果传输到MySQL Server层进行where过滤。

优化效果:ICP可以减少引擎层访问基表和MySQL Server访问存储引擎的次数,减少io数量,提高查询语句性能。

当ICP开启时,MySQL会使用索引过滤存储引擎层的数据,以减少不必要的返回表。请注意,在虚线中使用where意味着如果where条件包含未被索引的字段,它仍然需要由MySQL Server层进行筛选。

ICP :的使用限制。

1当sql需要全表访问时,ICP的优化策略可以用于range、ref、eq_ref、ref_or_null类型的数据访问方法。

2支持InnoDB和MyISAM表。

3 ICP只能用于二级指标,不能用于一级指标。

4并非所有条件都可以通过电感耦合等离子体进行筛选。

如果where条件的字段不在索引列中,则应将整个表的记录读取到服务器进行where筛选。

ICP的加速效果取决于存储引擎中ICP过滤掉的数据比例。

6.6版不支持子表的ICP功能,5.7版支持。

7当sql使用覆盖索引时,不支持ICP优化方法。

看完这篇文章,相信大家对“MySQL索引条件下推(ICP)的使用有哪些限制”有一定的了解。想了解更多,请关注行业信息渠道。感谢您的阅读!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/66421.html

(0)

相关推荐

  • Windows中能够提取出图片边缘特征的网络是什么

    技术Windows中能够提取出图片边缘特征的网络是什么这篇文章主要介绍“Windows中能够提取出图片边缘特征的网络是什么”,在日常操作中,相信很多人在Windows中能够提取出图片边缘特征的网络是什么问题上存在疑惑,小

    攻略 2021年11月9日
  • 怎么开源你的Python库

    技术怎么开源你的Python库这篇文章主要介绍了怎么开源你的Python库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、源码将代码放在 GitHub

    攻略 2021年10月26日
  • mean什么意思,whatimean什么意思

    技术mean什么意思,whatimean什么意思what i mean我的意思双语对照例句:1.Fishermen will know what I mean. 爱钓鱼的人知道我的意思mean什么意思。 2.Saves

    生活 2021年10月29日
  • 怎么理解JavaScript中的语法和代码结构

    技术怎么理解JavaScript中的语法和代码结构本篇内容主要讲解“怎么理解JavaScript中的语法和代码结构”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解Jav

    攻略 2021年11月20日
  • STL栈与队列

    技术STL栈与队列 STL栈与队列#includequeue// 队列
    #includestack//栈stackint s;//参数也是数据类型,这是栈的定义方式
    queueint q; //参

    礼包 2021年12月3日
  • Python性能分析

    技术Python性能分析 Python性能分析性能分析装饰器
    # line profile
    import time
    from functools import wraps
    from line_profi

    礼包 2021年10月27日