MySQL slow query and optimization test. For more information, see
MySQL slow query and optimization test. For more information, see
Edit the my. cnf or my. ini file and remove the comments of the following lines of code:
The Code is as follows:
Log_slow_queries =/var/log/mysql/mysql-slow.log.
Long_query_time = 2
Log-queries-not-using-indexes
This will record slow queries and queries without indexes.
After doing so, execute the tail-f command on the mysql-slow.log file and you will be able to see slow queries that record them and queries that do not use indexes.
Extract A Slow query and execute explain:
The Code is as follows:
Explain low_query
You will see the following results:
+ ---- + ------------- + --------------------- + ------ + ------------- + ------ + --------- + ------ + ------------- +
| Id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+ ---- + ------------- + --------------------- + ------ + ------------- + ------ + --------- + ------ + ------------- +
| 1 | SIMPLE | some_table | ALL | NULL | 166 | Using where |
+ ---- + ------------- + --------------------- + ------ + ------------- + ------ + --------- + ------ + ------------- +
Note the preceding rows and key columns. Rows shows the number of rows affected by this query. We do not want to make this value too large. Key indicates which index is used. If it is NULL, no index is used for the query.
To make the query faster, you may need to add an index for some columns:
Create index myapp_mytable_myfield_idx on myapp_mytable (myfield );
In addition to configuring the mysql configuration file to achieve slow query of records, the following methods can be used to record slow queries:
The Code is as follows:
SELECT t. TABLE_SCHEMA AS 'db ',
T. TABLE_NAME AS 'table ',
S. INDEX_NAME AS 'index name ',
S. COLUMN_NAME AS 'field name ',
S. SEQ_IN_INDEX 'seq IN Index ',
S2.max _ columns AS '# cols ',
S. cardinality as 'Card ',
T. TABLE_ROWS AS 'est rows ',
ROUND (s. CARDINALITY/IFNULL (t. TABLE_ROWS, 0.01) * 100), 2) AS 'sel %'
FROM INFORMATION_SCHEMA.STATISTICS s
Inner join INFORMATION_SCHEMA.TABLES t ON s. TABLE_SCHEMA = t. TABLE_SCHEMA AND s. TABLE_NAME = t. TABLE_NAME
Inner join (
SELECT TABLE_SCHEMA, TABLE_NAME, INDEX_NAME, MAX (SEQ_IN_INDEX) AS max_columns
FROM INFORMATION_SCHEMA.STATISTICS
WHERE TABLE_SCHEMA! = 'Mysql' group by TABLE_SCHEMA, TABLE_NAME, INDEX_NAME) AS s2 ON s. TABLE_SCHEMA = s2.TABLE _ schema and s. TABLE_NAME = s2.TABLE _ name and s. INDEX_NAME = s2.INDEX _ NAME
WHERE t. TABLE_SCHEMA! = 'Mysql'/* Filter out the mysql system DB */
AND t. TABLE_ROWS> 10/* Only tables with some rows */
AND s. cardinality is not null/* Need at least one non-NULL value in the field */
AND (s. CARDINALITY/IFNULL (t. TABLE_ROWS, 0.01) <1.00/* unique indexes are perfect anyway */
Order by 'sel % ', s. TABLE_SCHEMA, s. TABLE_NAME/* DESC for best non-unique indexes */
LIMIT 10;