Mysql索引优化(一)_索引类型

栏目: 数据库 · 发布时间: 5年前

内容简介:索引对于良好的性能非常关键,尤其是在数据量越来越大的时候。恰当的索引对性能的帮助是非常巨大的,不恰当的索引不禁不能对性提升有帮助,当数据量达到一定级别的时候还可能造成性能的下降。所以了解索引对Mysql索引基本类型有

索引对于良好的性能非常关键,尤其是在数据量越来越大的时候。恰当的索引对性能的帮助是非常巨大的,不恰当的索引不禁不能对性提升有帮助,当数据量达到一定级别的时候还可能造成性能的下降。所以了解索引对 Mysql 性能优化有着至关重要的作用。

Mysql索引基本类型有 B-Tree , 哈希索引 , 全文索引 , 空间数据索引(R-Tree) 。其中 B-Tree哈希全文索引 是我们经常用到的。

B-Tree索引

B-Tree 索引是我们口中经常说的索引类型(有些存储引擎中使用的是B+Tree。如InnoDB)。每个引擎对于BTREE索引使用方式是不一样的。

  • MyISAM 引擎使用的是前置压缩技术,这样索引会变的很小。而 InnoDB 则是按照原有的数据格式来存储的。
  • MyISAM 索引是通过数据的物理位置来找到被索引的行,而 InnoDB 则是根据被索引的行的主键来找到被索引行的。

B-Tree 索引的所有值都是按顺序存储的,并且每个叶子节点到根节点的距离是相同的。下面给出一个简单的示意图

Mysql索引优化(一)_索引类型

假设有下表:

CREATE TABLE student(
    first_name varchar(20) not null,
    last_name varchar(20) not null,
    age tinyint(3) not null,
    created_at timestamp not null,
    key(first_name ,last_name)
);

可以使用到 B-Tree 索引的查询

  • 全值匹配 全值匹配指对索引中的所有列进行匹配。如查询姓名是 zhang san 的人 select * from student where first_name='zhang' and last_name='san'; 这里使用了索引的第一列与第二列
  • 匹配最左前缀,如查询姓为 的人 select * from student where first_name='zhang' ; 这里使用了索引的第一列
  • 匹配列前缀,也可以值匹配某一列的开头部分,如 select * from student where first_name='zha' ; 这里使用了索引的第一列
  • 匹配范围值,如 select * from student where first_name>'bao' and first_name<'zhang'; 这样也会使用到索引的第一列
  • 只访问索引的查询,如果查询条件是 select first_name,last_name from student where first_name='zhang' ; 那么查询就只会访问索引,而不会再去根据主键回表查询数据。

这里需要注意的是; B-Tree 索引需要根据最左前缀查询,如果不是按照索引的最左列开始查询,那么是不会使用到索引的。例如:

select * from student where last_name='san';

select * from student where first_name like '%ha%'; 这样的 sql 是没办法命中索引的。对于第二条 sql 如果需要使用索引,那么应该改为 select * from student where first_name like 'ha%';

哈希索引

哈希索引是基于哈希表实现的,只有精确匹配索引所有列的查询才会使用到索引,只有 Memory 引擎才支持哈希索引。

假设有下表:

CREATE TABLE student(
    first_name varchar(20) not null,
    last_name varchar(20) not null,
    age tinyint(3) not null,
    created_at timestamp not null,
    key using hash(first_name)
) engine=memory;

如果我们要执行 select last_name from student where first_name='zhang'; , Mysql 会先计算 zhang 的哈希值,然后用该值寻找对应的记录指针,最后再去比较 first_name 是否等于 zhang

因为哈希索引只存储对于的哈希值和行指针,所以哈希索引的结构很紧凑,查询速度非常快。但是也有一些缺点。

  • 因为哈希索引只有哈希值与指针,所以每次查询必须回表去读取数据行。
  • 因为哈希索引不是按照索引值顺序存储的,所以哈希索引也不能用于排序。
  • 哈希索引不支持部分索引列查询,比如 将 student 表是索引 改为 hash(first_name,last_name) ,那么查询必须用到 first_name,last_name 才会使用到索引。
  • 哈希索引只支持等值比较,所以 <,> 等范围查询是不会使用到索引的。
  • 哈希索引也会存在哈希冲突,当出现冲突的时候,查询效率就很降低很多。

Mysql索引优化(一)_索引类型


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

网络英雄传

网络英雄传

郭羽、刘波 / 江苏凤凰文艺出版社 / 2018-6 / 59.80元

“商战鬼才郭羽、营销奇才刘波强强联手,凝集十年实战经验,倾力打造商战巨作。” 这是一个商业竞争和资本激战交织的惊心动魄的创业交锋故事。 由郭天宇、刘帅共同创立的在线旅游公司万全天盛凭借其出色的商业模式异军突起,与老牌巨头“51旅游网”两强相争,但国际巨头通远来势汹汹,国内在线旅游市场进入战火纷飞的“三国杀”时代,分踞杭、沪、京三地互相“搏杀”。中国新兴的互联网公司面对国际巨头的入侵,毫不退缩......一起来看看 《网络英雄传》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换