登录
首页 >  数据库 >  MySQL

MySQL - RANGE优化篇

来源:SegmentFault

时间:2023-01-16 18:29:13 401浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《MySQL - RANGE优化篇》,文章讲解的知识点主要包括MySQL,如果你对数据库方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

SELECT * FROM t1
  WHERE key_col > 1
  AND key_col 

提取过程

MYSQL会尽可能从索引中提取范围条件,在提取过程中,利用索引将不能提取范围条件的过滤掉,然后对剩下的数据进行额外的筛选

代码示例

参考以下句子,其中key1是一个索引列,nonkey没有索引:

SELECT * FROM t1 WHERE
  (key1  'z');
提取步骤

1.原始的

(key1  'z')

2.使用 TRUE 来替换不能进行范围扫描的

(key1  'z')

3.折叠始终为真或者假的条件

(key1 LIKE 'abcde%' OR TRUE)     总是如此
(key1  'z')   总是假的

常数替代

(key1 

去除不必要的TRUE和 FALSE常数

(key1 

4.最后将重叠的时间间隔合并为一个,产生用于范围扫描的最终条件

(key1 

一般来说(和前面的例子一样),用于范围扫描的条件与WHERE子句相比限制性更小。MySQL会执行额外的检查来筛选满足范围条件但不满足WHERE子句的行。

范围条件提取的算法可以处理任意深度的嵌套AND / OR结构,其输出并不依赖于条件出现在WHERE子句中的顺序。

复合索引

复合索引的范围条件是单个索引范围条件提取的扩展

限制内存

使用系统变量

Warning    3170    Memory capacity of N bytes for
                   'range_optimizer_max_mem_size' exceeded. Range
                   optimization was not done for this query.
范围表达式内存估算准则

1.多个

SELECT COUNT(*) FROM t
WHERE a=1 OR a=2 OR a=3 OR .. . a=N;

2.

SELECT COUNT(*) FROM t
WHERE a=1 AND b=1 AND c=1 ... N;

3.

SELECT COUNT(*) FROM t
WHERE a IN (1,2, ..., M) AND b IN (1,2, ..., N);

行构造器

MYSQL写法优化的一种,简化了书写,不过这种方式只支持

SELECT ... FROM t1 WHERE ( col_1, col_2 ) IN (( 'a', 'b' ), ( 'c', 'd' ));
早期写法

SELECT ... FROM t1 WHERE ( col_1 = 'a' AND col_2 = 'b' )
OR ( col_1 = 'c' AND col_2 = 'd' );

总结

最好的优化方案,跟着新版本走

推陈出新
,新版中不仅扩展更多功能,同时会加强优化力度。虽然

MySQL优化器
为我们做了很多事情,但开发过程中该主意还得注意。

说点什么

关注微信公众号:

battcn
后台回复
mysql
即可获得
《打造扛得住的MySQL数据库架构》
  • 个人QQ:1837307557
  • battcn开源群(适合新手):391619659

理论要掌握,实操不能落!以上关于《MySQL - RANGE优化篇》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表