Detailed explanation of MySQL combined index method

Detailed explanation of MySQL combined index method

For any DBMS, indexes are the most important factor for optimization. For a small amount of data, not having a suitable index does not have a big impact, but as the amount of data increases, performance will drop sharply.

If you index multiple columns (composite index), the order of the columns is very important. MySQL can only effectively search for a prefix of the leftmost column of the index. For example:

Assume that there is a composite index (c1, c2), the query select * from t1 where c1=1 and c2=2 can use this index. The query select * from t1 where c1=1 can also use this index. However, the query statement select * from t1 where c2=2 cannot use this index because there is no leading column for the composite index. That is, in order to use the c2 column for search, c1 must be equal to a certain value.

For example:
Create two tables book (book table) and bookclass (book classification table)

select b.ISBN FROM book b where b.CATEGORY_ID = 1; 

這里寫圖片描述

Execution time: 0.053s

Use explain to analyze the SQL:

這里寫圖片描述

type = ALL Extra=Using where, the full table query does not use the index.

EXPLAIN shows how MySQL uses indexes to process select statements and join tables. It can help choose better indexes and write more optimized query statements.

ALL For each combination of rows from the previous tables, a full table scan is performed. This is usually bad if the table is the first table not marked const, and is usually very bad in other cases. Often you can add more indexes instead of using ALL so that rows can be retrieved based on constant values ​​or column values ​​in the previous table.

Create a composite index:
create index index_isbn on book (CATEGORY_ID,ISBN);

Execute the SQL again and find that the time is shortened to 0.009s

這里寫圖片描述

Use explain to analyze the SQL:

這里寫圖片描述

type = ref, Extra = Using index Index query is used.

ref For each combination of rows from the previous tables, all rows with matching index values ​​will be read from this table. If the join uses only a leftmost prefix of the key, or if the key is not UNIQUE or PRIMARY KEY (in other words, if the join cannot select a single row based on the key), then ref is used. This join type is good if the keys used match only a small number of rows.

This is the end of this article about the detailed explanation of the combined index method of MySQL. For more relevant MySQL combined index content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • MySql index improves query speed common methods code examples
  • Summary of several situations in which MySQL indexes fail
  • Detailed explanation of MySQL clustered index and non-clustered index
  • Solutions to Mysql index performance optimization problems
  • Summary of some common writing methods that cause MySQL index failure
  • Various types of MySQL indexes
  • MySQL performance optimization: how to use indexes efficiently and correctly
  • Basic syntax of MySQL index
  • Reasons and solutions for MySQL selecting the wrong index

<<:  Linux uses suid vim.basic file to achieve privilege escalation

>>:  Vue uses OSS to upload pictures or attachments

Recommend

Solution to the failure of entering the container due to full docker space

Since the problem occurred rather suddenly and th...

Details on using JS array methods some, every and find

Table of contents 1. some 2. every 3. find 1. som...

Vue keeps the user logged in (various token storage methods)

Table of contents How to set cookies Disadvantage...

React passes parameters in several ways

Table of contents Passing parameters between pare...

CentOS7 installation GUI interface and remote connection implementation

Use the browser (webdriver)-based selenium techno...

MySQL 8.0.20 installation tutorial and detailed tutorial on installation issues

Original address: https://blog.csdn.net/m0_465798...

The normal method of MySQL deadlock check processing

Normally, when a deadlock occurs, the connection ...

Use HTML and CSS to create your own warm man "Dabai"

The final result is like this, isn’t it cute… PS:...

How to view the status of remote server files in Linux

As shown below: The test command determines wheth...

js code to realize multi-person chat room

This article example shares the specific code of ...

Two types of tab applications in web design

Nowadays, tabs are widely used in web design, but...

How to Easily Remove Source Installed Packages in Linux

Step 1: Install Stow In this example, we are usin...

Some data processing methods that may be commonly used in JS

Table of contents DOM processing Arrays method Su...

Summary of some thoughts on binlog optimization in MYSQL

question Question 1: How to solve the performance...

JavaScript microtasks and macrotasks explained

Preface: js is a single-threaded language, so it ...