Mysql > select * from table where index = ‘index’; select * from table where index = ‘index’;
Many people will say that the index is equivalent to a book table of contents, through the table of contents to find a certain page in the book, is really fast, if there is no table of contents, you need to turn over the book page by page, greatly reducing efficiency. This metaphor is actually quite appropriate, is a very classic index metaphor.
In InnoDB, each index is actually a B+ tree. The primary key index is called clustered index, and the other non-primary key index is called secondary index. The value of each row in each table is completely stored in the primary key index leaf node, and the secondary index leaf node stores the primary key value.
Mysql index is a B+ tree. Juejin. Cn/post / 684490…
This means that each table has at least one primary key index, and all rows in the table are stored on the leaf node of the B+ tree. If you add an index to other columns of the table, the index is a secondary index, which is also a B+ tree.
The difference between a secondary index and a primary key index is that the values stored on the leaf node of the primary key index are different. The values of all fields in the table are completely stored on the leaf node of the primary key index, while the leaf node of the secondary index only stores the values corresponding to the primary key.
Let’s take a concrete example to illustrate this problem. Create primary key index (id,k,m); create secondary index (k, k,m);
mysql> create table t( id int primary key, k int not null, m int(11), index (k)) engine=InnoDB;
Then insert some data into the table, represented by R1, R2, R3, R4, R5, insert specific data as follows: The (id,k,m) values of R1~R5 are (100,1,1000), (200,2,2000), (300,3,3000), (500,5,5000), (600,6,6000) respectively.
As mentioned earlier, the primary key index leaf node stores the entire row value, and the secondary index leaf node stores the primary key value. Therefore, the data of the above table T is stored in mysql as shown in the following diagram.
Table T has three columns, and there are no indexes on field M, so there are two indexes on table T, so there should be two B+ trees, and there should be as many B+ trees as there are indexes on a table.
Let’s look at the differences between queries with and without indexes.
For example, the following SQL statement, there is no available index, so we can only scan the entire table, that is, scan the primary key index from the beginning to the end of the leaf node, and then compare the value of field M in each row to screen out the records that meet the conditions. This query is very inefficient.
select * from t where m > 1000 and m < 3000;
Look at the other an SQL statement, this statement can be used to index k, so the query will go to the secondary index k B + tree and quickly find meet the requirements of leaf nodes, and the leaf node here is only preserved the primary key value, so also need to get through the primary key ID value back to find out all the fields on the primary key index value, This process is called table-back.
select * from t where k > 3 and k < 6;
This is why mysql queries are faster when indexes are added to the table. In fact, this process can be further optimized by using overwrite indexes, which will be discussed later in this article.
If you have any questions, please leave a comment, it is not easy to be original, if the article is helpful to you, I hope you can give the article a thumbs up, thanks for your support, and the pictures in the article come from geek Time column.