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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 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;

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

最后的最后送大家一句话

白驹过隙,沧海桑田

与君共勉


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
关系型数据库 MySQL 索引
MySQL的全文索引查询方法
【8月更文挑战第26天】MySQL的全文索引查询方法
39 0
|
2月前
|
自然语言处理 关系型数据库 MySQL
MySQL MATCH 匹配中文 无法查询的问题如何处理?
【8月更文挑战第27天】MySQL MATCH 匹配中文 无法查询的问题如何处理?
141 62
|
21天前
|
SQL 缓存 关系型数据库
MySQL高级篇——关联查询和子查询优化
左外连接:优先右表创建索引,连接字段类型要一致、内连接:驱动表由数据量和索引决定、 join语句原理、子查询优化:拆开查询或优化成连接查询
MySQL高级篇——关联查询和子查询优化
|
24天前
|
SQL 关系型数据库 MySQL
MySQL查询(万字超详细版)
本文详细介绍了数据库中的单表和多表查询方法。首先,单表查询包括全列查询、指定列查询及去重查询,其中应避免使用`*`以提高效率。接着,文章讲解了排序查询,包括升序和降序,并展示了如何通过多个字段进行排序。在多表查询部分,本文解释了内连接、外连接(左外连接和右外连接)以及自连接的概念和用法,提供了丰富的代码示例
24 1
MySQL查询(万字超详细版)
|
6天前
|
存储 关系型数据库 MySQL
MySQL索引失效及避免策略:优化查询性能的关键
MySQL索引失效及避免策略:优化查询性能的关键
23 3
|
8天前
|
关系型数据库 MySQL 数据库
MySQL 表的CRUD与复合查询
【9月更文挑战第26天】本文介绍了数据库操作中的 CRUD(创建、读取、更新、删除)基本操作及复合查询。创建操作使用 `INSERT INTO` 语句插入数据,支持单条和批量插入;读取操作使用 `SELECT` 语句查询数据,可进行基本查询、条件查询和排序查询;更新操作使用 `UPDATE` 语句修改数据;删除操作使用 `DELETE FROM` 语句删除数据。此外,还介绍了复合查询,包括连接查询(如内连接、左连接)和子查询,以及聚合函数与分组查询,并提供了示例代码。
|
11天前
|
关系型数据库 MySQL 数据库
Python MySQL查询返回字典类型数据的方法
通过使用 `mysql-connector-python`库并选择 `MySQLCursorDict`作为游标类型,您可以轻松地将MySQL查询结果以字典类型返回。这种方式提高了代码的可读性,使得数据操作更加直观和方便。上述步骤和示例代码展示了如何实现这一功能,希望对您的项目开发有所帮助。
37 4
|
14天前
|
NoSQL 关系型数据库 MySQL
当Redis与MySQL数据一致性校验中Redis数据量小于MySQL时的全量查询处理方法
保持Redis和MySQL之间的数据一致性是一个需要细致规划和持续维护的过程。通过全量数据同步、建立增量更新机制,以及定期执行数据一致性校验,可以有效地管理和维护两者之间的数据一致性。此外,利用现代化的数据同步工具可以进一步提高效率和可靠性。
35 6
|
11天前
|
关系型数据库 MySQL
mysql查询速度慢怎么解决?
mysql查询速度慢怎么解决?
32 2
|
10天前
|
关系型数据库 MySQL
mysql & clinkhouse之查询 行拼接
mysql & clinkhouse之查询 行拼接
mysql & clinkhouse之查询 行拼接
下一篇
无影云桌面