Mysql单表访问方法图文示例详解

 更新时间:2023年07月04日 08:33:26   作者:Zeran  
这篇文章主要为大家介绍了Mysql单表访问方法图文示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

访问方法的概念

设计MySQL的大叔把MySQL执行查询语句的方式称为访问方法(access method)或者访问类型。同一个查询语句可以使用多种不同的访问方法来执行,虽然最后的查询结果都是一样的,但是不同的执行方式话费的时间成本可能差距甚大。就像是从北京南锣鼓巷到什刹海,你可以打车去,也可以坐地铁去,坐公交去,还可以骑共享单车去,当然也可以走着去。

表结构

CREATE TABLE single_table(
    id int not null auto_increment,
    key1 VARCHAR(100),
    key2 int,
    key3 VARCHAR(100),
    key_part1 VARCHAR(100),
    key_part2 VARCHAR(100),
    key_part3 VARCHAR(100),
    common_field VARCHAR(100),
    PRIMARY KEY(id),
    key idx_key1(key1),
    unique key uk_key2(key2),
    key idx_key3(key3),
    key idx_key_part(key_part1,key_part2,key_part3)
)engine=INNODB charset=utf8mb4

const

有时需要通过主键列定位一条记录,如下:

select * from single_table where id = 12;

MySQL会直接利用主键值在聚簇索引中定位对应的用户记录,如下:

与之类似,我们根据唯一二级索引列来定位一条记录的速度也是贼快的。比如下面的查询:

select * from single_talbe where key2 = 12;

这个查询的执行过程的示意图如下:

可以看到这个查询的执行分为下面两步:

  • 步骤1. 在uk_key2对应的B+树索引中,根据key2列与常数的等值比较条件定位到一条二级索引记录。
  • 步骤2. 然后再根据该记录的id值到聚簇索引中获取到完整的用户记录。

设计MySQL的大叔认为,通过主键或者唯一二级索引列与常数的等值比较来定位一条记录像是坐火箭一样快的,所以他们把这种通过主键或者唯一二级索引列来定位一条记录的访问方法定义为const(意思是常数级别的,代价是可以忽略不计的)。不过这种const访问方法只能在主键列或者唯一二级索引列与一个常数进行等值比较时才有效。如果主键或者唯一二级索引的索引列由多个列构成,则只有在索引列中的每一个列都与常数进行等值比较时,这个const访问方法才有效(这是因为只有在该索引的每一个列都采用等值比较时,才可以保证最多只有一条记录符合搜索条件)。

对于唯一二级索引来说,在查询列为null值时,情况比较特殊。比如下面这样:

select * from single_table where key2 is null;

因为唯一二级索引列并不限制null值的数量,所以上述语句可能访问到多条记录。也就是说上面这个语句不可以使用const访问方法来执行。

以上就是Mysql单表访问方法的详细内容,更多关于Mysql单表访问方法的资料请关注脚本之家其它相关文章!

相关文章

  • Ubuntu10下如何搭建MySQL Proxy读写分离探讨

    Ubuntu10下如何搭建MySQL Proxy读写分离探讨

    MySQL Proxy是一个处于你的Client端和MySQL server端之间的简单程序,它可以监测、分析或改变它们的通信
    2012-11-11
  • MySQL实现分页查询的方法

    MySQL实现分页查询的方法

    这篇文章介绍了MySQL实现分页查询的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • MYSQL数据库GTID实现主从复制实现(超级方便)

    MYSQL数据库GTID实现主从复制实现(超级方便)

    这篇文章主要介绍了MYSQL数据库GTID实现主从复制实现(超级方便),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Mysql 5.6.24安装实例教程

    Mysql 5.6.24安装实例教程

    这篇文章主要介绍了Mysql 5.6.24安装实例教程,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12
  • MySQL按时间统计数据的方法总结

    MySQL按时间统计数据的方法总结

    在本篇MYSQL的内容里,我们给大家整理了关于按时间统计数据的方法内容,有需要的朋友们学习下。
    2019-02-02
  • mysql 如何插入随机字符串数据的实现方法

    mysql 如何插入随机字符串数据的实现方法

    这篇文章主要介绍了mysql 如何插入随机字符串数据的实现方法,需要的朋友可以参考下
    2016-09-09
  • MySQL索引的基本语法

    MySQL索引的基本语法

    这篇文章主要介绍了MySQL索引的基本语法,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • MySQL where和having的异同

    MySQL where和having的异同

    我们在进行查询的时候,经常需要按照条件对查询结果进行筛选,这就要用到条件语句where和having了,本文主要介绍了MySQL where和having的异同,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • MySQL对数据表已有表进行分区表的实现

    MySQL对数据表已有表进行分区表的实现

    本文主要介绍对现有的一个表进行创建分区表,并把数据迁移到新表,可以按时间来分区,具有一定的参考价值,感兴趣的可以了解一下
    2021-10-10
  • SQL语句单引号与双引号的使用方法

    SQL语句单引号与双引号的使用方法

    这篇文章主要介绍了SQL语句中单引号、双引号的使用方法,分别讲述,虽然说的是Insert语句, 但是Select、Update、Delete语句都是一样的,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-03-03

最新评论