Thresh
Slow query location
Enable the slow query log function Check whether the slow query log function and the storage location of the log file are enabled in the MySQL database as follows:
SHOW VARIABLES LIKE 'slow_query_log%'
Copy the code
Run the following command to enable slow log query:
SET global slow_query_log = ON; SET global slow_query_log_file = 'OAK-slow.log'; SET global log_queries_not_using_indexes = ON; SET long_query_time = 10; Long_query_time: specifies the threshold for slow queries, in seconds. If the SQL execution time exceeds the threshold, it is a slow query logged to the log file. Log_queries_not_using_indexes: records SQL queries that do not use indexes. Slow_query_log is ON, otherwise it won't work)Copy the code
View slow query logs
To view information in text mode, open slow.log in a text editor.
Time: log time User@Host: user and host that executes Query_time: execution time Lock_time: lock table time Rows_sent: number of records and results sent to the requestor Rows_examined: SET TIMESTAMP: statement execution time select.... : Indicates the specific SQL statement to executeCopy the code
Use mysqlDumpslow to view
MySQL provides a slow query log analysis tool, mysqlDumpslow, which can be used to analyze slow query log content.
Run the following command in the MySQL bin directory to view the usage format.
Usage: mysqldumpslow [ OPTS... ] [ LOGS... ] -- followed by arguments and the absolute address of the log file; -s what to sort by (al, at, ar, c, l, r, t), 'at' is default al: average lock time ar: average rows sent at: average query time c: count l: lock time r: rows sent t: query time -r reverse the sort order (largest last instead of first) -t NUM just show the top n queries -a don't abstract all numbers to N and strings to 'S' -n NUM abstract numbers with at least n digits within names -g PATTERN grep: only consider stmts that include this string -h HOSTNAME hostname of db server for *-slow.log filename (can be wildcard), default is '*', i.e. match all -i NAME name of server instance (if using mysql.server startup script) -l don't subtract lock time from total timeCopy the code
Example:
Mysqldumpslow -s c -t 10 /var/run/mysql/mysqld-slow-. log mysqldumpslow -s t -t 3 Mysqldumpslow -s t -t 10 -g "left join" /database/mysql/slow-log # Mysqldumpslow -s r -t 10 -g 'left join' /var/run/mysql/mysqld-slow-. log # mysqldumpslow -s r -t 10 -g 'left join' /var/run/mysql/mysqld-slow-Copy the code
In addition to using the mysqlDumpslow tool, you can also use third-party analysis tools such as Pt-Query-Digest, mysqlSLA, and so on. zhuanlan.zhihu.com/p/106405711
Slow query optimization
Indexes and slow queries
- How do I determine whether the query is slow?
MySQL determines whether a statement is a slow query statement based on the execution time of the SQL statement. It compares the execution time of the current statement with the long_QUERy_time parameter. If the execution time of the statement is greater than long_query_time, the statement is recorded in the slow query log. The default value of long_query_time is 10s, which can be adjusted based on service requirements.Copy the code
- How do I determine if an index is applied?
You can run the explain command to check whether the KEY value in the SQL statement is NULL based on whether the table index is used during the SQL statement execution.Copy the code
- Is an index necessarily fast?
select * from user where id>0; Although the index is used, the whole index tree is scanned from the leftmost leaf of the primary key index to the right, and the index becomes meaningless. Select * from user where id = 2; This statement is what we normally call the use of index. What it means is that we use the quick search capabilities of the index and effectively reduce the number of rows scanned.Copy the code
Query whether to use an index, only indicates the execution process of an SQL statement; A slow query is determined by the time it is executed, which means that there is no correlation between the use of an index and a slow query.
When we use an index, we should not only focus on whether it works, but also on whether it reduces the number of rows scanned by the query. If the number of rows scanned is reduced, efficiency will be improved. For a large table, you should not only create an index, but also consider index filtering, which will be fast.
Alter table sex=’ male ‘; alter table sex=’ male ‘; alter table sex=’ male ‘; In fact, this problem is related to the filter of the index. For example, the filter of 10, 100 and 1000 records is different. Index filtering is related to index fields, the amount of data in the table, and the design structure of the table.
Summary of causes for slow query
Full table scan: explain type attribute all Full index scan: explain type attribute index Filter is not good: rely on index field selection, data volume and status, table design frequent back table query overhead: use select * as little as possible, use overwrite indexCopy the code
Paging query optimization
General paging General paging queries can be implemented using a simple limit clause. Limit format:
SELECT * FROM table name LIMIT rows OFFSET sizeCopy the code
If the offset is fixed, how does size affect the execution time?
When querying records, the number of returned records is less than 100, and the query time is basically unchanged with a small gap. As the number of query records increases, it takes more and more time.Copy the code
What is the effect of a fixed number of returned records on execution time if the query offset changes?
If the number of query records is the same and the offset exceeds 100, the query time increases sharply as the offset increases. (This paged query mechanism starts with the first record in the database and slows down the subsequent queries, and the more data you query, the slower the overall query speed.)Copy the code
The first step of paging optimization: use overlay index optimization
Select * from user limit 10000,100; Select id from user limit 10000,100;Copy the code
Step 2: Optimize with subqueries
Select * from user limit 10000,100; Select * from user where id>= (select id from user 10000,1) limit 100;Copy the code
Reason: ID primary key comparison is used (ID >=) and subqueries are optimized with overwrite indexes
MySQL > update MySQL
A. Do not use * (the database will be converted into a * field) B. Here multi-condition query, the result set conditions less put in front of C. N (first check inner table), inner table small use; If exists, use d. If the inner table is large, use like less. Full-text search can be performed. If exists, avoid double-wildcards and use e effectively. Increase the number of redundant fields and reduce the number of joint table queries f. Make proper use of retrieval (not suitable for writing, suitable for reading) h. Read/write separation I. Replace hardware with disk arrays or SSDS g. When a large amount of data is generated, separate database tables......... , etc.Copy the code