Index failure this question should be the premise of the index is not used, or not fully used, the following is a list of common reasons, may also smell in the interview.
Reason 1: For example, create a composite index (login_name, name, mobile), If the index is matched separately by name or mobile (i.e. WHERE name = ‘name’ AND mobile = ‘mobile’), it will not take effect.
The composite index must adhere to the left-most prefix, which is the order in which the composite index was created, and the left column must appear in that order.
If intermediate fields are default, such as WHERE login_name = ‘name’ AND mobile = ‘mobile’, the compound index will not be fully used, only the index of the login_name part will be used, AND not completely invalidated.
Ps: However, IN my work, I have hardly met the scenario of building composite indexes. It may be that the conditions for using composite indexes are relatively strict, so it is not useful to establish composite indexes. Business scenarios do not have such requirements.
Reason two: For example, SELECT * FROM sys_user WHERE left(login_name, 4) = ‘haha’. You can see from Explain that this SQL statement will perform a full table scan in ALL mode
SELECT * FROM sys_user WHERE login_name LIKE ‘haha%’.
Disallow any calculation of indexed columns; Note, however, that only the index column is not allowed to evaluate, if a value is evaluated, as in the following example:
mysql> explain select * from user where name like CONCAT(left('name', 1), '%'); +----+-------------+-------+------------+-------+---------------+----------+---------+------+------+----------+--------- -----------------+ | id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra | +----+-------------+-------+------------+-------+---------------+----------+---------+------+------+----------+--------- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- + | | 1 SIMPLE | user | NULL | range | idx_name | idx_name | 767 | NULL | | | 100.00 6 Using the where; Using index | +----+-------------+-------+------------+-------+---------------+----------+---------+------+------+----------+--------- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- + 1 row in the set, 1 warning (0.00 SEC)Copy the code
Cause three: the scope condition occurs, and all will be invalid in the future
SQL > alter table SELECT (); SQL > alter table SELECT (); In the second SQL query, the SELECT clause uses *, indicating that all fields are queried, which is inefficient.
The SELECT clause disallows the use of * to query all fields.
It is not true that SELECT * cannot use the index, but it is possible to use the index when all columns are selected to create a federated index, but this does not make sense.
Reason 5: Use does not equal (! = or <>) as a condition