B+树索引使用(6)左原则 --mysql从入门到精通(十八)

2023-01-30 00:00:00 索引 查询 节点 的是 行号

上篇文章我们说了,myISAM表和innoDB表的不同,myISAM吧用户记录数据放在数据文件,会给每行数据一个行号,myISAM会给主键生成索引,吧索引页放在索引文件。B+树的叶子节点存储的是主键+行号,意味着次通过主键查询只能查到行号,之后回表,通过行号查询数据文件整行数据。而innoDB的聚簇索引不需要二次查询。

索引的代价

理解索引的原理之后,就会知道索引并不是没有缺点的。

1、空间上的代价:我们知道每个页都是16kb大小,而一颗b+树有每个节点都属于一个页,这样建立太多索引对空间内存占用非常大。

2、时间上的代价:索引会吧每个页按从小到大组成一个双向链表,内节点或者底层叶子节点里的数据也是按索引从小到大组成一个单向链表,这样每次进行增,删,改操作可能都会对节点排序和页记录进行破坏,所以如果建立太多索引,对表的增删改性能影响很大。


B+树索引使用场景

下面我们开始使用b+树索引,所有使用技巧都源于你对b+树索引特征本质的理解,如果你还不能理解前面的文章,建议你去读一遍,不然下面的文字对你来说是一种折磨,看了就会忘记。下面我们来介绍b+树索引的查询情况,先建立个表,存储人的基本信息,设置id为主键,这样innoDB会默认创年聚簇索引,在显示创建idx_name_birthday_phone为复合索引,所以在列b+树的叶子节点会有name,birthdate,phone和主键id,不会有country。

mysql> create table person_info(
    -> id int not null auto_increment,
    -> name varchar(100) not null,
    -> birthday date not null,
    -> phone char(11) not null,
    -> country varchar(100) not null,
    -> primary key (id),
    -> key idx_name_birthday_phone (name,birthday,phone)
    -> );
Query OK, 0 rows affected (0.05 sec)

相关文章