index condition pushdown是MySQL5.6的新特性,主要是对MySQL索引使用的优化。

Index condition push简称ICP,索引条件下推,将索引条件从server层下推到storage engine层。

此时出现ICP现象,但ICP到底是个什么现象呢。
1、ICP的开启和关闭方法:
set optimizer_switch=’index_condition_pushdown=on|off’
2、ICP使用限制:
ICP适用于MyISAM和InnoDB表,对于InnoDB表只能用于二级索引。
MySQL5.6版本的分区表还没有ICP功能,官网文档介绍将于5.7版本中解决。
3、ICP的目的在于减少完整读取一条记录的次数,从而减少IO的操作。
4、
当优化器没有使用ICP的时候,数据的访问和提取:
当storage engine层读取记录的时候,首先使用索引定位并读取整条记录,server层再根据where条件决定该条记录是否使用。

当优化器使用ICP的时候,数据的访问和提取:
当storage engine层读取记录的时候,首先测试where条件中索引列(由server层下推到storage engine层的索引条件)决定该条记录是否可用,如果可用,则索引定位的记录完整读取出来,让server层根据where条件决定该条记录是否使用。

5、实例演示:
首先有如下表结构:

CREATE TABLE `icp_test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`code` int(11) DEFAULT NULL,
`name` varchar(16) DEFAULT NULL,
`address` varchar(16) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `idx_c_n_a` (`code`,`name`,`address`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

分析如下操作:

select * from icp_test where code=18 and name like '%A%' ;
select * from icp_test where code=18 and name like '%A%' ;

做如下分析:
优化器在没有ICP的条件下:
select * from icp_test where code=18 and name like ‘%A%’ ;

优化器在有ICP的条件下:

分析:
在没有ICP的条件下,虽然有idx_c_n_a(code,name.address)索引,但由于where条件中name like ‘%A%’不使用索引,所以storage engine层只能使用code=18过滤得到4条记录返回到server层,此时server层根据name like ‘%A%’得到两条符合条件的记录返回客户端。

在有ICP的条件下,有idx_c_n_a(code,name,address)索引,where条件中name like ‘%A%’不使用索引,所以storage engine层只能使用code=18过滤得到4条记录,但此时不立即返回server层,由于MySQL5.6版本的索引条件下推(ICP)的特性,stora engine层还会根据索引中的name列name like ‘%A%’过滤得到2条记录返回客户端,此时没有非索引列的where条件,最终返回客户端。

MySQL5.6新特性Index conditontion pushdow的更多相关文章

  1. [MySQL5.6 新特性] 全局事务标示符(GTID)

    GTID的全称为 global transaction identifier  , 可以翻译为全局事务标示符,GTID在原始master上的事务提交时被创建.GTID需要在全局的主-备拓扑结构中保持唯 ...

  2. MySQL5.6 新特性之GTID【转】

    转自 MySQL5.6 新特性之GTID - jyzhou - 博客园http://www.cnblogs.com/zhoujinyi/p/4717951.html 背景: MySQL5.6在5.5的 ...

  3. MySQL5.7新特性

    MySQL5.7介绍 身处 MySQL 这个圈子,能够切身地感受到大家对 MySQL 5.7 的期待和热情,似乎每个人都迫不及待的想要了解.学习和使用 MySQL 5.7.那么,我们不禁要问, MyS ...

  4. mysql5.7新特性探究

    一.MySql5.7增加的特性 1.MySql服务方面新特性 1) 初始化方式改变 MySql5.7之前版本初始化方式: scripts/mysql_install_db MySql5.7版本初始化方 ...

  5. mysql5.6新特性总结

    一. server参数默认值设置的变化http://dev.mysql.com/doc/refman/5.6/en/server-default-changes.html 二. innodb增强1.全 ...

  6. 使用mysql5.7新特性(虚拟列)解决使用前通配符性能问题

    众所周知,在mysql里的后通配符可以使用索引查找,前通配查询却无法使用到索引,即使是使用到了索引,也是使用了索引全扫描,效率依然不高,再MySQL5.7之前,一直都没有好的办法解决,但是到了MySQ ...

  7. 使用mysql5.7新特性解决前通配符查询性能问题

    众所周知,在mysql里的后通配符可以使用索引查找,前通配查询却无法使用到索引,即使是使用到了索引,也是使用了索引全扫描,效率依然不高,再MySQL5.7之前,一直都没有好的办法解决,但是到了MySQ ...

  8. MySQL5.6 新特性之GTID

    背景: MySQL5.6在5.5的基础上增加了一些改进,本文章先对其中一个一个比较大的改进"GTID"进行说明. 概念: GTID即全局事务ID(global transactio ...

  9. [转]MySQL5.6新特性之Multi-Range Read

    这几天看到mrr的东西,刚好看到以前我们组的一个小伙的博客,我看挺全的,就转过来了,原博客地址请戳 一 介绍    MySQL 5.6版本提供了很多性能优化的特性,其中之一就是 Multi-Range ...

随机推荐

  1. java输出菱形

    package test; public class Test { public static void main(String[] args) { for(int i=1;i<=4;i++){ ...

  2. java.lang.IllegalArgumentException: View not attached to window manager

    公司项目线上bug: java.lang.IllegalArgumentException: View not attached to window manager at android.view.W ...

  3. 第一百二十二节,JavaScript表单处理

    JavaScript表单处理 学习要点: 1.表单介绍 2.文本框脚本 3.选择框脚本 为了分担服务器处理表单的压力,JavaScript提供了一些解决方案,从而大大打破了处处依赖服务器的局面. 一. ...

  4. Haskell Json数据处理

    json的基本类型为——string, numbers, Booleans以及null,定义json类型如下 -- file: Json.hs module Json where data JValu ...

  5. 运行CUDA实例时候出现的问题

    问题一:>LINK : fatal error LNK1123: 转换到 COFF 期间失败:文件无效或损坏 将 项目——项目属性——配置属性——连接器——清单文件——嵌入清单 “是”改为“否” ...

  6. NVIC

    1中断:每一个中断都会对应一个服务程序 2NVIC 他的做用是负责中断优先级管理 3IP bit[7:4]每一个中断都有一个IP寄存器,用于设置中断相关的属性 AIRCR[10:8]只一个AIRCR寄 ...

  7. opencv BP神经网络使用过程

       1.OpenCV中的神经网络 OpenCV中封装了类CvANN_MLP,因而神经网络利用很方便.   首先构建一个网络模型:     CvANN_MLP ann;     Mat structu ...

  8. php入门 数据类型 运算符 语言结构语句 函数 类与面向对象

    php PHP-enabled web pages are treated just like regular HTML pages and you can create and edit them ...

  9. 雄冠条码PV系统-2016-05-17-收获

    Q1:微信浏览器 input获取焦点时,页面宽度变大 解决方法: HTML <header> 中添加<meta name="viewport" content=& ...

  10. RPC框架基本原理(三):调用链路分析

    本文主要阐述下RPC调用过程中的寻址,序列化,以及服务端调用问题. 寻址 随机寻址 从可用列表中,随机选择地址 一致性寻址 可用服务地址一致性hash管理:根据可服务的地址,构造treemap,计算c ...