《MySQL》索引

前提知识

下面例子都以Innodb为例

数据是存储在磁盘上的,MySQL是一款专门管理数据的软件。既然MySQL要管理数据,而数据又在磁盘上,所以MySQL在管理数据的时候,一定会进行IO操作

  • MySQL进行IO操作的基本单位是16KB(page)
  • MySQL为了减少IO操作,设置有Buffer Pool大内存空间(128M)进行各种缓存,来和磁盘数据进行IO交互。

索引定义和结构

索引:在内存中存在的一种数据结构。

理解数据文件结构

MySQL中的数据文件基本都是通过一个个page构成的。

MySQL是由C语言制作的,page是一个16KB大小的结构体,用于存储MySQL里的数据文件内容。

在这里插入图片描述
page的表结构是双向链表。

之前说过,MySQL是尽量减少IO操作,缩短等待时间。为例减少IO,提高查询效率,page引入了目录,并且进行了分级目录,最终的大结构如下:
在这里插入图片描述
如图,索引的底层结构就是B+树。该数据结构存在BufferPool里

一张索引表对应一棵B+树。该结构只有叶子节点存数据,叶子结点间形参双向链表;非叶子节点只存目录项。

B+树结构来存储数据的优势

相对于链表,二叉搜索树,红黑树,查找快,减少了IO操作;相比于hash表,还支持范围查找

索引分类

  • 聚簇索引:数据和索引在一起(Innodb)

在这里插入图片描述

聚簇索引会出现回表查询,过程就是普通索引找到主键,再由主键索引找数据。(如图)

在这里插入图片描述

  • 非聚簇索引:数据和索引分离(MyISAM)

在这里插入图片描述

索引操作

主键索引:建立主键时自动创建,删除主键时自动删除。
唯一索引:添加唯一键属性时自动创建,删除唯一键属性时自动删除。(唯一键索引属于其他索引)
其他索引:

# 添加索引
alter table 表名 add index(字段);
# 查看索引
show index from 表名;
show key from 表名;

在这里插入图片描述

# 删除索引
alter table 表名 drop index 索引名
drop index 索引名 on 表名

拓展知识

索引覆盖

在查询过程中,数据库只需通过索引就能够满足查询的需求,而不需要再去访问数据表。换句话说,查询所需的列都包含在索引中,不需要再去读取数据表中的其他列。

复合索引

复合索引的创建方式是将多个列的索引组合在一起,按照指定的顺序创建。

例如,可以创建一个包含两个列的复合索引:(列1, 列2)。这样的索引可以提供按照列1和列2的组合进行查询的能力。

在复合索引中还有个一个索引最左匹配原则,这是指在使用复合索引进行查询时,查询条件必须按照索引中列的顺序进行匹配,而且只能使用索引的最左边的连续列。使用复合索引时,如果不按照最左匹配原则,则会导致索引失效

索引失效

  • 当我们使用左或者左右模糊匹配的时候,也就是 like %xx 或者 like %xx%这两种方式都会造成索引失效;
  • 当我们在查询条件中对索引列做了计算、函数、类型转换操作,这些情况下都会造成索引失效;
  • 联合索引要能正确使用需要遵循最左匹配原则,也就是按照最左优先的方式进行索引的匹配,否则就会导致索引失效。
  • 在 WHERE 子句中,如果在 OR 前的条件列是索引列,而在 OR 后的条件列不是索引列,那么索引会失效。

全文索引

当对文章字段或有大量文字的字段进行检索时,会使用到全文索引。MySQL提供全文索引机制,但是有要求,要求表的存储引擎必须是MyISAM,而且默认的全文索引支持英文,不支持中文。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL索引是一种数据结构,可以帮助MySQL快速定位和访问表中的数据。使用索引可以提高查询效率,降低数据库的负载。下面是MySQL索引的一些基本概念和使用方法: 1. 索引类型 MySQL支持多种类型的索引,包括B树索引、哈希索引、全文索引等。其中,B树索引是最常用的一种,也是默认的索引类型。B树索引可以用于精确匹配和范围查询,而哈希索引主要用于等值查询,全文索引则用于文本检索。 2. 索引创建 可以在创建表时指定索引,例如: ``` CREATE TABLE users ( id INT PRIMARY KEY, name VARCHAR(50), email VARCHAR(50), INDEX idx_email (email) ); ``` 也可以在已有的表上添加索引,例如: ``` ALTER TABLE users ADD INDEX idx_name (name); ``` 3. 索引使用 查询语句中可以使用WHERE子句和ORDER BY子句来利用索引,例如: ``` SELECT * FROM users WHERE email = '[email protected]'; SELECT * FROM users WHERE name LIKE 'John%' ORDER BY id DESC; ``` 需要注意的是,索引并不是越多越好,过多的索引会占用过多的磁盘空间并降低写操作的性能。因此,需要根据实际情况选择合适的索引。同时,还需要定期对索引进行维护,包括优化查询语句、删除不必要的索引等。 4. 索引优化 MySQL提供了一些工具来优化索引,例如EXPLAIN命令可以帮助分析查询语句的执行计划,找出慢查询和不必要的全表扫描。可以使用OPTIMIZE TABLE命令来优化表的索引和碎片,从而提高查询性能。还可以使用缓存来避免频繁的查询操作,例如使用Memcached或Redis等缓存工具。 以上就是MySQL索引的一些基本概念和使用方法,需要根据实际情况进行选择和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值