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
相关文章
|
1月前
|
存储 关系型数据库 MySQL
环比、环比增长率、同比、同比增长率 ,占比,Mysql 8.0 实例(最简单的方法之一)(sample database classicmodels _No.2 )
环比、环比增长率、同比、同比增长率 ,占比,Mysql 8.0 实例(最简单的方法之一)(sample database classicmodels _No.2 )
92 1
|
10天前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
42 9
|
12天前
|
缓存 监控 关系型数据库
如何优化MySQL查询速度?
如何优化MySQL查询速度?【10月更文挑战第31天】
39 3
|
17天前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
16天前
|
关系型数据库 MySQL
Mysql 中日期比较大小的方法有哪些?
在 MySQL 中,可以通过多种方法比较日期的大小,包括使用比较运算符、NOW() 函数、DATEDIFF 函数和 DATE 函数。这些方法可以帮助你筛选出特定日期范围内的记录,确保日期格式一致以避免错误。
|
16天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
82 1
|
22天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
18天前
|
SQL 关系型数据库 MySQL
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
38 1
|
17天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第26天】数据库作为现代应用系统的核心组件,其性能优化至关重要。本文主要探讨MySQL的索引策略与查询性能调优。通过合理创建索引(如B-Tree、复合索引)和优化查询语句(如使用EXPLAIN、优化分页查询),可以显著提升数据库的响应速度和稳定性。实践中还需定期审查慢查询日志,持续优化性能。
47 0
|
18天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
30 0