文档章节

Mysql学习——区间查询优化(Range Optimization)

 空无一长物
发布于 2016/07/11 13:58
字数 446
阅读 11
收藏 1
点赞 0
评论 0

单个索引

1.1 BTREE and HASH 索引:使用=,<=>,IN,IS NULL,IS NOT NULL操作

1.2 BTREE 索引: >,<,>=,<=,BETWENN,!=, <>, LIKE(不是以通配符开头)

1.3 所有索引,多个区间条件可以用OR或者AND连接

例:

SELECT * FROM t1 WHERE key_col > 1 AND key_col < 10;

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';

一些非常数值转换成常数值在优化器的常数传播时期(constant propagation phase)

Mysql会尽可能将区间查询条件中的索引提取出来。在这个提取阶段会做如下几件事:

1 那些无法构成区间条件的条件将会被删除.

2 区间重叠的条件将会合并

3 空范围的将会被删除

例:

SELECT * FROM t1 WHERE(key1是索引,nonkey不是索引)

(key1 < 'abc' AND (key1 LIKE 'abcd%' OR key1 LIKE '%b')) OR

(key1 < 'bar' AND nonkey = 4) OR

(key1 < 'uux' AND key1 > 'z');

提取过程(对于index key1)如下:

删除nonkey = 4 和 key1 LIKE '%b',因为这两个条件无法使用区间扫描,正确的方式是将这两个替换成TRUE,这样我们就不会漏掉任何一条匹配的行了

(key1 < 'abc' AND (key1 LIKE 'abcd%' OR TRUE)) OR

(key1 < 'bar' AND TRUE) OR

(key1 < 'uux' AND key1 > 'z');

条件替换(可以确定为TRUE OR FALSE的值)

(key1 LIKE 'abcde%' OR TRUE) is always true

(key1 < 'uux' AND key1 > 'z') is always false

替换之后

(key1 < 'abc' AND TRUE) OR (key1 < 'bar' AND TRUE) OR (FALSE)

删除不必要的 TRUE 和 FALSE

(key1 < 'abc') OR (key1 < 'bar')

合并重叠部分则变成了

(key1 < 'bar')
 

通常情况下,范围扫描的限制性是小于WHERE。Mysql在检查过滤行时会优先满足范围条件而不是所有的WHERE条件

© 著作权归作者所有

共有 人打赏支持
粉丝 2
博文 67
码字总数 27922
作品 0
深圳
mysql 索引 index range

今天在调试一个BUG的时候,无意间发现 explain 发现了 index range; 之前对于索引的理解是,单个索引每次查询只能用一个索引。于是赶紧查一下,果然存在这个优化器在适当的时候会选择使用两个...

小小人故事
2015/12/21
537
0
MySQL学习——排序算法

简介 本文主要介绍当在MySQL中执行order by时,MySQL使用的排序算法。当在select语句中使用order by语句时,MySQL首先会使用索引来避免执行排序算法;在不能使用索引的情况下,可能使用 快速...

沈渊
2017/09/24
0
0
MySQL系列教程(二)

mySQL执行计划 语法 explain 例如: snippetid="1888919" snippetfilename="blog201609201_4697977" name="code" class="plain">explain select * from t3 where id=3952602; explain输出解释......

lifetragedy
2016/09/20
0
0
[慢查优化]建索引时注意字段选择性 & 范围查询注意组合索引的字段顺序

写在前面的话: 之前曾说过“不要求每个人一定理解 联表查询(join/left join/inner join等)时的mysql运算过程”,但对于字段选择性差意味着什么,组合索引字段顺序意味着什么,要求每个人必须...

旁观者-郑昀
2013/09/22
0
1
MySQL Explain详解

MySQL Explain详解 若想查看MySQL优化器优化后的sql语句可以使用如下语句: Explain输出字段解释 Explain输出字段: Column 含义 id 查询序号 select_type 查询类型 table 表名 partitions 匹...

Gen_zhou
2016/10/25
216
0
只需几步即可提升你的 SQL 技能

如果你习惯了使用 ActiveRecord 或者 SQLAlchemy,当你需要编写 SQL 的时候就会茫然失措,但,并不是只有你一个人会这样。 只需要一些时间来练习,你就可以像专家一样编写高级的查询。 坚实的...

OSC编辑部
2015/08/05
1K
9
如何高效快速地优化MySQL、SQL语句(附源码)

作者介绍 韩锋,宜信技术研发中心数据库架构师。精通多种关系型数据库,曾任职于当当网、TOM在线等公司,曾任多家公司首席DBA、数据库架构师等职,多年一线数据库架构、设计、开发经验。著有...

Yomut
2016/10/10
135
0
GROUP BY另类优化技巧

分享嘉宾:知数堂〖SQL开发优化班〗讲师郑松华,韩国Infobridge的SQL优化专家&7年SQL开发和调优经验&资深数据库工程师。 本次主题《GROUP BY另类优化技巧》,主要内容是从 GROUP BY、ORDER B...

iMySQL | 老叶茶馆
2017/04/15
0
0
MySQL EXPLAIN的输出信息

MySQL EXPLAIN的输出信息 基本用法 explain article; explain select * from article a where a.author_id in (select author_id from user); 第一个相当于desc表结构。 第二个表示select查......

秋风醉了
2015/08/23
0
0
如何用一款小工具大大加速MySQL SQL语句优化(附源码)

作者介绍 韩锋,宜信技术研发中心数据库架构师。精通多种关系型数据库,曾任职于当当网、TOM在线等公司,曾任多家公司首席DBA、数据库架构师等职,多年一线数据库架构、设计、开发经验。著有...

韩锋
2016/09/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

20位活跃在Github上的国内技术大牛 leij 何小鹏 亚信

本文列举了20位在Github上非常活跃的国内大牛,看看其中是不是很多熟悉的面孔? 1. lifesinger(玉伯) Github主页: https://github.com/lifesinger 微博:@ 玉伯也叫射雕 玉伯(王保平),...

海博1600
7分钟前
0
0
高性能服务器本质论

一 服务器分类 从软件性能角度,高性能服务器分:cpu密集型服务器/IO密集型服务器 (1)CPU密集型:该类服务器没有对io的访问/没有同步点,性能瓶颈在于对cpu的充分利用。 典型的如转发服务器/...

码代码的小司机
8分钟前
0
0
Mybatis收集配置

一、Mybatis取Clob数据 1、Mapper.xml配置 <resultMap type="com.test.User" id="user"> <result column="id" property="id"/> <result column="json_data" property="jsonData" ......

星痕2018
33分钟前
0
0
centos7设置以多用户模式启动

1、旧版本linux系统修改inittab文件,在新版本执行vi /etc/inittab 会有以下提示 # inittab is no longer used when using systemd. # # ADDING CONFIGURATION HERE WILL HAVE NO EFFECT ON......

haha360
今天
0
0
OSChina 周日乱弹 —— 局长:怕你不爱我

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @ andonny :分享周二珂的单曲《孤独她呀》 《孤独她呀》- 周二珂 手机党少年们想听歌,请使劲儿戳(这里) @孤星闵月 :没事干,看一遍红楼梦...

小小编辑
今天
181
9
Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式 Factory工厂模式 Singleton单例模式 Delegate委派模式 Strategy策略模式 Prototype原型模式 Template模板模式 Spring5 beans 接口实例化 代理Bean操作 ...

小致dad
今天
0
0
SpringBoot | 第十章:Swagger2的集成和使用

前言 前一章节介绍了mybatisPlus的集成和简单使用,本章节开始接着上一章节的用户表,进行Swagger2的集成。现在都奉行前后端分离开发和微服务大行其道,分微服务及前后端分离后,前后端开发的...

oKong
今天
11
0
Python 最小二乘法 拟合 二次曲线

Python 二次拟合 随机生成数据,并且加上噪声干扰 构造需要拟合的函数形式,使用最小二乘法进行拟合 输出拟合后的参数 将拟合后的函数与原始数据绘图后进行对比 import numpy as npimport...

阿豪boy
今天
17
0
云拿 无人便利店

附近(上海市-航南路)开了家无人便利店.特意进去体验了一下.下面把自己看到的跟大家分享下. 经得现场工作人员同意后拍了几张照片.从外面看是这样.店门口的指导里强调:不要一次扫码多个人进入....

周翔
昨天
1
0
Java设计模式学习之工厂模式

在Java(或者叫做面向对象语言)的世界中,工厂模式被广泛应用于项目中,也许你并没有听说过,不过也许你已经在使用了。 简单来说,工厂模式的出现源于增加程序序的可扩展性,降低耦合度。之...

路小磊
昨天
251
1

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部