mysql索引的理解

发布日期:

数据库基础:讲解MySQL索引的概念及数据库索引的应用[1]

1、MySQL索引是一种数据结构,可以使数据库在查询数据时更快地找到匹配的记录。它能够加速查询,因为它创建了一个引用表,其中包含主要查询字段的排序数据。

2、MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。我们可以简单理解为:快速查找排好序的一种数据结构。Mysql索引主要有两种结构:B+Tree索引和Hash索引。

3、在数据库表中,使用索引可以大大提高查询速度。

MySQL和ES的索引对比

ES的索引不是B+Tree树,而是倒排索引,ES的倒排索引由 Term index,Term Dictionary和Posting List 组成的。

MySQL支持全文索引和搜索功能。在MySQL中可以在CHAR、VARCHAR或TEXT列使用FULLTETXT来创建全文索引。

mysql底层B-tree 支持矮胖,高胖的时候就很难受,说白了就是数据量多会增加IO操作。ES底层倒排索引。

mysql索引最左原则原理

1、而最左原则的原理就是,因为联合索引的B+Tree是按照第一个关键字进行索引排列的。

2、比如当(张三,F)这样的数据来检索时,b+树可以用name来指定搜索方向,但下一个字段age的缺失,所以只能把名字等于张三的数据都找到,然后再匹配性别是F的数据了, 这个是非常重要的性质,即索引的最左匹配特性。

3、在MySQL建立联合索引时会遵守最左前缀匹配原则,即最左优先,在检索数据时从联合索引的最左边开始匹配。. 要想理解联合索引的最左匹配原则,先来理解下索引的底层原理。

4、最左匹配原则:最左优先,以最左边的为起点任何连续的索引都能匹配上。同时遇到范围查询(、、between、like)就会停止匹配。

5、底层原理 首先要知道,最左前缀原则是针对联合索引的,索引就要知道联合索引的实现原理。它的底层是一个B+树,但键值数是大于1的。

6、最左原则原理指的是当使用联合索引进行查询时,最左侧的索引列必须包含在查询条件中,并且尽量不要使用从右往左的联合索引列。