mysql查询语句的访问方法const、ref、ref_or_null、range、index、all

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: mysql查询语句的访问方法const、ref、ref_or_null、range、index、all

设计mysql的专家们把mysql执行查询的方式称为访问方法或者访问类型,也有人叫做访问级别。同一个查询语句可以使用多种不同的访问方法来执行,虽然最后的查询结果都是一样的,但是不同的执行方式花费的成本可能差距巨大。

下面我们来看一个下mysql都有哪些访问方法,以及他们各自的执行效率

假设我们有demo_table表,id列为主键,key2列为唯一二级索引列,key1为普通索引列

1、const

  • 通过主键来定位一条记录
select * from demo_table where id = 2;
  • 通过唯一二级索引来定位一条记录
select * from demo_table where key2 = 'zhangsan01';

规定通过主键或者唯一二级索引列常数的等值比较来定位一条记录的访问方法定义为const

2、ref

有时我们需要通过某个普通二级索引列常数进行等值比较,比如:

select * from demo_table where key1 = 'abc';

我们知道对于上面用到的二级索引,对应的扫描区间是[‘abc’,‘abc’],这是一个单点扫描区间,==我们可以定位到第一条’abc’的记录,然后沿着记录所在的单向链表向后扫描,直到某条记录不等于’abc’为止。==由于查询的列表是*,因此需要获取到每一条二级索引记录后都需要拿着id再去聚簇索引中查询完整的用户记录,也就是需要执行回表。

由于二级索引不会限制索引列的唯一性,所以通过二级索引查询的记录可能有多条,此时使用二级索引执行查询的代价就取决于扫描区间中的记录条数。

我们把搜索条件为二级索引列与常数进行等值比较,形成的扫描区间为单点扫描区间,采用二级索引来执行查询的访问方法称为ref

3、ref_or_null

有时,我们不仅想找出某个二级索引列的值等于某个常数的记录,而且还想把该列中值为NULL的记录也找出来,比如:

select * from demo_table where key1 = 'abc' OR key1 is NULL;

当使用二级索引而不是全表扫描的方式执行该查询时,对应的扫描区间就是[NULL,NULL]和[‘abc’,‘abc’],此时这种类型的查询所使用的访问方法就称为ref_or_null

4、range

有时候,我们的查询方法很复杂,比如下面这个sql

select * from demo_table where key2 in (1438,6328) OR (key2 >= 38 and key2 <= 79);

如果使用key2列的索引idx_key2来执行该查询,那么对应的扫描区间就是[1438,1438],[6328,6328], [38,79]。

我们把使用索引执行查询时,对应的扫描区间为若干个单点扫描区间或者范围扫描区间的访问方法称为range(仅包含一个单点扫描区间的访问方法不能称为range访问方法,扫描区间为(负无穷,正无穷)的访问方法也不能称为range)

5、index

我们来看下面这个查询

select key1 from demo_table;  // key1是普通二级索引

上面的sql无法形成合适的扫描区间,因为没有条件,无法使用ref或者range的访问方法,但是我们可以直接遍历所有的二级索引记录,因为我们查询的列只有key1,这是一个二级索引列,所以我们不需要回表,这种方式也称为覆盖索引。

我们把这种扫描全部二级索引记录的访问方法称为index访问方法。

6、all

最直接的查询方式就是全表扫描,对应InnoDB来说就是直接扫描全部的聚簇索引记录。

我们把这种使用全表扫描执行查询的访问方法称为all访问方法。

这些访问方法的执行级别排名

效率最高到最低

const > ref > ref_or_null > range > index > all

我们可以通过 EXPLAIN 来查看sql的执行的访问方法,其中type列就是所使用的访问方法比如

EXPLAIN SELECT line_item_id from task_center;

创作不易,点个赞或者加个收藏吧~👍

最后的最后送大家一句话

白驹过隙,沧海桑田

与君共勉


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
存储 SQL JSON
【MySQL从入门到精通】【高级篇】(二十五)EXPLAIN中ref、rows、filtered、Extra字段的剖析
上一篇文章我们介绍了 【MySQL从入门到精通】【高级篇】(二十四)EXPLAIN中select_type,partition,type,key,key_len字段的剖析,重点介绍了EXPLAIN命令的select_type,partition,type,key,key_len 字段含义。这篇文章我将接着介绍剩余字段的含义。本文会介绍ref、rows、filtered、Extra这几个字段。比较重要的两个字段是rows、Extra
1098 0
【MySQL从入门到精通】【高级篇】(二十五)EXPLAIN中ref、rows、filtered、Extra字段的剖析
|
关系型数据库 MySQL 索引
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(五)
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(五)
172 0
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(五)
|
存储 关系型数据库 MySQL
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(四)
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(四)
161 0
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(四)
|
关系型数据库 MySQL 索引
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(三)
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(三)
153 0
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(三)
|
关系型数据库 MySQL
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(二)
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(二)
142 0
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(二)
|
SQL 关系型数据库 MySQL
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(一)
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(一)
136 0
MYSQL性能调优02_Explain概述、详解id、select_type、table、type、possible_keys、key、key_len、ref、rows、Extra列(一)
|
Oracle 关系型数据库 MySQL
oracle index unique scan/index range scan和mysql range/const/ref/eq_ref的区别
关于oracle index unique scan/index range scan和mysql range/const/ref/eq_ref type的区别    关于ORACLE index unique scan和index range scan区别在于是否...
1682 0
|
3月前
|
机器学习/深度学习 SQL 关系型数据库
【MySQL进阶之路丨第十一篇】一文带你精通MySQL NULL值处理、正则表达式
【MySQL进阶之路丨第十一篇】一文带你精通MySQL NULL值处理、正则表达式
36 0
|
3月前
|
SQL 关系型数据库 MySQL
总结 vue3 的一些知识点:MySQL NULL 值处理
总结 vue3 的一些知识点:MySQL NULL 值处理
|
5月前
|
SQL 关系型数据库 MySQL
MySQL NULL 值处理
MySQL NULL 值处理