mysql 区间索引_MySQL索引优化(四)—— 范围查询优化

本文详细介绍了MySQL中如何进行范围查询优化,特别是针对区间索引的使用。通过单值和复合索引,分析了范围查询的条件提取、区间合并以及不同索引类型的处理方式,帮助理解MySQL如何高效处理不等值和BETWEEN等查询操作。
摘要由CSDN通过智能技术生成

范围查询可以通过一个索引的单个或者多个索引值的区间来检索数据记录,也适用于符合索引。下面就区间是怎么样从where子句中被提取出来的作出详细解释。

使用单值索引的范围查询

对于单值索引来说索引值的区间能够很好地通过where子句中的相应条件很好的表示出来。

单值索引的范围查询被定义为:对于BTree索引和Hash索引来讲,包含索引键和 =, <=>, IN(), IS NULL 或者 IS NOT NULL 这些操作符的比较

此外对于BTree索引来讲还包含索引键和 >, =, <=, BETWEEN, !=, 或<>, 或 LIKE不以通配符开头的 这些操作符的比较

对于所有的索引类型,多个索引条件用 or 或者 and 组合的单个范围查询

下面这些是范围查询SELECT * FROM t1 WHERE key_col > 1 AND key_col 

SELECT * FROM t1 WHERE key_col = 1 OR key_col IN (15,18,20);

SELECT * FROM t1 WHERE key_col LIKE 'ab%' OR key_col BETWEEN 'bar' AND 'foo';

一些非常量的值是可以被优化器转为常量的。

MySQL会在提取范围查询条件的时候会为每个索引提取。在提取的过程中,不能构成范围查询条件的将会被丢弃,重叠的范围查询条件将会被合并,构成空的范围查询的将会被移除。

参考下面的语句,key1 是被索引的, nonkey是没被索引的SELECT * FROM t1 WHERE

(key1 

(key1 

(key1  'z');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值