Introduction:
Select… The optimizations in the WHERE sentence apply to delete or update
Focus on
To improve the performance of where clauses, you may sacrifice a bit of code readability, because mysql automatically performs similar optimizations, so avoid where clauses.
Remove unnecessary parentheses:
((a and b) and c or(((a and b) and (c and d))))) 改为 :(a and b and c) or(a and b and c and d)Copy the code
Constant folding:
(a<b and b=c) and b>5 and b=c and a=5Copy the code
Constant condition extraction:
(b >=5 and b=5) or (b=6 and 5=5) or (b=7 and 5=6) or (b=7 and 5=6Copy the code
Some policies in MySQL 8.0.14 and later
- The value expression used by the index is evaluated only once
- Count (*) is retrieved directly from table information MyISAM and MEMORY tables on forms without a.
- Not NULL Is used when only one table is queried. It can also be used in expressions.
- Early detection of invalid constant expressions does not revert to any lines.
- Havingwhere merges if group by or aggregate functions count(),min(), etc. are not applicable
- For each table in the link, WHERE constructs a simple WHERE table to quickly retrieve the table and skip rows as quickly as possible
All constant tables are read first before any other tables in the query. Below is the constant scale
- An empty table or a row table.
- A table used with a clause on a or index WHERE all index parts are compared with a constant expression defined as primary KeyUNIQUenot NULL
select * from t where primary_key=1;
select *from t1,t2 where t1.primary_key=1 and t2.primary_key=t1.id
Copy the code
- If the columns in the order BY and group by sentences are all from the same table, then that table should be the first to join.
- If the ORDER BY clause and a different group by clause, or order by or Group BY contain columns other than the first table in the linked queue, the temporary table is created.
- If the SQL_SMALL_result modifier is used, mysql uses the memory zero-hour table.
- In most cases, the optimal index is used, unless the optimizer uses table scans more efficiently, based on whether the optimal index is used across more than 30% of the table, but the percentage does not necessarily determine the biggest factor in using indexes and scans. The optimizer also makes an estimated selection (based on table size, row I/O fast size).
- In some cases, mysql reads rows directly from the index without consulting the data file. If all numbers are used in the index, the index tree can be used to parse the query.
- Having skips lines that do not match the word before a line is output.
Some examples of very fast queries:
select count(*) from tab; select min(key_par1) ,max(key_par1) from tab; select max(key_part2) from tab where key_part1 = constant; select ... from tab order by key_part1,key_part2,..... limit 10; select ... from tab order by key_part1 desc, key_part2 desc, .... limit 10;Copy the code
Mysql only uses index tree to parse the query, assuming that the index columns are all numbers:
select key_p1,key_p2 from tab where key_p1 = val;
select count(*) form tab where key_p1 =val1 and key_par2 = val2;
select key_p2 from tab group by key_p1;
Copy the code
Use an index to sort a search, rather than a separate sort pass:
select ... from tab order by key_p1,keyp2... ; select ... from tab order by key_p1 desc , keyp_2 desc , .... ;Copy the code
Mysql optimization: blog.csdn.net/weixin_4274…
The article continues to update, forwarding indicates that the source is convenient to update!