Under what circumstances will mysql index fail?
Several cases of mysql index failure: 1. If there is or in the condition, even if there is a condition with an index, it will not be used; 2. For a multi-column index, if the first part is not used, the index will not be used. ; 3. If the like query starts with %, the index is invalid; 4. When the field type is a string, the data in the condition is not quoted in quotation marks.
(Recommended tutorial: mysql video tutorial)
The index does not take effect all the time For example, the following situations will cause the index to fail:
1. If there is or in the condition, even if there is a condition with an index, it will not be used ( This is why you should use or as little as possible)
## Note : If you want to use or and want the index to take effect, you can only add an index to each column in the or condition
2. For multi-column indexes , if it is not the first part used, the index will not be used
3. The like query starts with %, and the index is invalid; when the like prefix does not have %, the suffix has %, the index is valid.
## 4. If the column type is a string, then it must The data must be quoted in quotation marks in the condition, otherwise the index will not be used
# 5. If mysql estimates using the full table If the scan is faster than using the index, then the index is not used
show status like 'Handler_read%'; Everyone can pay attention to: handler_read_key: The higher the value, the better. The higher the value, the higher the number of queries using the index.
handler_read_rnd_next: The higher the value, the query is inefficient.
2) The guide column is not used in the query condition
#3) The number of queries is the majority of the large table, which should be more than 30%.
4) The index itself is invalid
5) The query condition uses a function in the index column on, or perform operations on index columns, operations include (, -, *, /,!, etc.) Wrong example: select * from test where id-1=9; Correct example: select * from test where id=10;
6) Query on small table
7) Prompt not to use index
8) Statistics are unreal
9) CBO calculation and indexing cost too much Condition. In fact, it also includes the above situation, which means that the block occupied by the table is smaller than the index.
10) Implicit conversion causes index failure. This should be taken seriously. It is also a common mistake in development. Since the table field tu_mdn is defined as varchar2 (20), but when querying, the field is passed to Oracle as a number type with a where condition, which will cause the index to fail. Wrong example: select * from test where tu_mdn=13333333333; Correct example: select * from test where tu_mdn ='13333333333';
##12) 1,<> 2,Separate>,<,(sometimes used, sometimes not )
13,like "%_" with the percent sign first.
14. The table has not been analyzed.
15, separately reference the index column that is not the first position in the composite index. 16, when the character field is a number Do not add quotation marks in the where condition. 17, perform operations on the index column. You need to create a function index. 18,not in ,not exist. 19, when the variable uses the times variable, and the table field uses date variable. Or vice versa. 20, B-tree index will not go if it is null, but will go if is not null, bitmap index will go if it is null, is not null 21. The joint index is not null as long as the index columns are created (in no particular order). When in null, it must be used together with the first column of the index. When the first position condition of indexing is is null, other indexed columns can be is null (but all columns must satisfy is null), or = a value; when the first position of indexing is = a value, other index columns can be in any situation (including is null = a value), and the index will go in the above two cases. It won't go under other circumstances.
The above is the detailed content of Under what circumstances will mysql index fail?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

The process of starting MySQL in Docker consists of the following steps: Pull the MySQL image to create and start the container, set the root user password, and map the port verification connection Create the database and the user grants all permissions to the database

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

I encountered a tricky problem when developing a small application: the need to quickly integrate a lightweight database operation library. After trying multiple libraries, I found that they either have too much functionality or are not very compatible. Eventually, I found minii/db, a simplified version based on Yii2 that solved my problem perfectly.

The key to installing MySQL elegantly is to add the official MySQL repository. The specific steps are as follows: Download the MySQL official GPG key to prevent phishing attacks. Add MySQL repository file: rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm Update yum repository cache: yum update installation MySQL: yum install mysql-server startup MySQL service: systemctl start mysqld set up booting

Installing MySQL on CentOS involves the following steps: Adding the appropriate MySQL yum source. Execute the yum install mysql-server command to install the MySQL server. Use the mysql_secure_installation command to make security settings, such as setting the root user password. Customize the MySQL configuration file as needed. Tune MySQL parameters and optimize databases for performance.

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

MySQL and phpMyAdmin are powerful database management tools. 1) MySQL is used to create databases and tables, and to execute DML and SQL queries. 2) phpMyAdmin provides an intuitive interface for database management, table structure management, data operations and user permission management.
