Table des matières
1 Idées d'optimisation des requêtes lentes
2 Journal des requêtes lentes
3 expliquer
5 优化器与索引
6 总结
Maison base de données tutoriel mysql Résumé et partage des idées d'optimisation des requêtes lentes MySQL

Résumé et partage des idées d'optimisation des requêtes lentes MySQL

Oct 12, 2022 pm 05:21 PM
mysql

Cet article vous apporte des connaissances pertinentes sur mysql, qui présente principalement les problèmes liés à l'optimisation des requêtes lentes, notamment l'utilisation de journaux de requêtes lentes pour localiser les requêtes lentes SQL, l'analyse des requêtes lentes SQL via l'explication et la modification de SQL autant que possible Laisser SQL utiliser l'index. Jetons-y un coup d'oeil. J'espère qu'il sera utile à tout le monde.

Résumé et partage des idées d'optimisation des requêtes lentes MySQL

Apprentissage recommandé : Tutoriel vidéo MySQL

1 Idées d'optimisation des requêtes lentes

Lorsqu'une requête lente se produit, l'idée d'optimisation est la suivante :

  • Utiliser les journaux de requêtes lentes pour localiser les requêtes lentes SQL

  • Analysez la requête lente SQL en expliquant

  • Modifiez le SQL et essayez de créer l'index SQL

2 Journal des requêtes lentes

MySQL fournit une fonction - le journal des requêtes lentes, qui enregistrera le SQL dont le temps de requête dépasse le seuil de temps spécifié. Dans le journal, il nous est pratique de localiser les requêtes lentes et d'optimiser les instructions SQL correspondantes.

Vérifiez d'abord les variables globales liées aux requêtes lentes dans MySQL :

mysql> show global variables like '%quer%';
+----------------------------------------+-------------------------------+
| Variable_name                          | Value                         |
+----------------------------------------+-------------------------------+
| binlog_rows_query_log_events           | OFF                           |
| ft_query_expansion_limit               | 20                            |
| have_query_cache                       | YES                           |
| log_queries_not_using_indexes          | OFF                           |
| log_throttle_queries_not_using_indexes | 0                             |
==========================================================================
| long_query_time                        | 10.000000                     |【1】慢查询的时间阈值
==========================================================================
| query_alloc_block_size                 | 8192                          |
| query_cache_limit                      | 1048576                       |
| query_cache_min_res_unit               | 4096                          |
| query_cache_size                       | 16777216                      |
| query_cache_type                       | OFF                           |
| query_cache_wlock_invalidate           | OFF                           |
| query_prealloc_size                    | 8192                          |
==========================================================================
| slow_query_log                         | OFF                           |【2】慢查询日志是否开启
| slow_query_log_file                    | /var/lib/mysql/Linux-slow.log |【3】慢查询日志文件存储位置
==========================================================================
+----------------------------------------+-------------------------------+
15 rows in set (0.00 sec)
Copier après la connexion

Ici, nous nous concentrons principalement sur trois variables :

  • long_query_time, le seuil de temps d'une requête lente, en secondes, si le temps d'exécution d'une instruction SQL dépasse cette valeur, Ensuite, MySQL l'identifie comme une requête lente

  • slow_query_log. Si la fonction de journalisation des requêtes lentes est activée. Elle est désactivée par défaut. Une fois activée, la requête lente est enregistrée

  • slow_query_log_file. .L'emplacement de stockage du fichier journal des requêtes lentes

Le journal des requêtes lentes par défaut La fonction est désactivée, nous devons donc l'activer

# 开启慢查询日志
mysql> set global slow_query_log=ON;
Query OK, 0 rows affected (0.00 sec)
# 设置慢查询时间阈值
mysql> set long_query_time=1;
Query OK, 0 rows affected (0.00 sec)
Copier après la connexion

Après l'avoir défini comme ceci, MySQL perdra ces configurations au redémarrage, et ils doivent être modifiés dans le fichier de configuration pour être efficaces de manière permanente.

3 expliquer

Nous pouvons utiliser expliquer pour analyser l'exécution d'instructions SQL, par exemple :

mysql> explain select sum(1+2);
Copier après la connexion

Les résultats de l'exécution sont les suivants, vous pouvez voir qu'il existe de nombreux champs

Résumé et partage des idées doptimisation des requêtes lentes MySQL

Nous examinons principalement certains champs importants field:

  • select_type représente le type de requête de l'instruction de requête, y compris une requête simple, une sous-requête, etc.

  • table représente la table de requête, qui n'existe pas nécessairement. Il peut s'agir d'une table temporaire obtenue dans cette requête.

  • type représente le type de récupération, utilise l'analyse complète de la table, l'analyse d'index, etc.

  • possible_keys indique les colonnes d'index qui peuvent être utilisées

  • keys indique les colonnes d'index réellement utilisées dans la requête, ce qui est déterminé par l'optimiseur de requête

3.1 champ select_type

Résumé et partage des idées doptimisation des requêtes lentes MySQL

3.2 champ type

Pour le moteur de stockage InnoDB, la colonne type est généralement all ou index.

Concernant la valeur du champ type, les performances d'exécution du SQL correspondant se dégradent progressivement de haut en bas. 3.3 Champ supplémentaire reee

Interception Données partielles :

Résumé et partage des idées doptimisation des requêtes lentes MySQL

Exécutez l'instruction SQL suivante sans utiliser de champs d'index :

create table user_info_large (
`id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '主键',
`account` VARCHAR(20) NOT NULL COMMENT '用户账号',
`name` VARCHAR(20) NOT NULL COMMENT '用户名',
`password` VARCHAR(20) not null COMMENT '用户密码',
`area` VARCHAR(20) NOT NULL COMMENT '用户地址',
`signature` VARCHAR(50) not null COMMENT '个性签名',
PRIMARY KEY (`id`) COMMENT '主键',
UNIQUE (`account`) COMMENT '唯一索引',
KEY `index_area_signture` (`area`,  `signature`)  COMMENT '组合索引'
);
Copier après la connexion
L'heure de la requête affichée par l'outil Navicat est la suivante : ce n'est pas l'heure à laquelle MySQL exécute réellement SQL. Elle inclut la transmission réseau et d'autres heures :

.

Résumé et partage des idées doptimisation des requêtes lentes MySQL

Spécifique à SQL Pour le temps de requête, vous pouvez consulter le journal des requêtes lentes :

mysql> select count(id) from user_info_large;
+-----------+
| count(id) |
+-----------+
|   2000000 |
+-----------+
1 row in set (0.38 sec)
Copier après la connexion
Explication sur certaines informations :

Time : L'heure de début de l'exécution SQL

Query_time : Le temps passé sur Requête d'instruction SQL, vous pouvez voir que cela a pris 10 secondes Clock

Résumé et partage des idées doptimisation des requêtes lentes MySQL

Lock_time : le temps d'attente pour la table de verrouillage

Rows_sent : le nombre d'enregistrements renvoyés par l'instruction Résumé et partage des idées doptimisation des requêtes lentes MySQL

Rows_examined : le nombre de enregistrements renvoyés par le moteur de stockage

  • La requête lente en cours d'exécution ne le sera pas. Si le journal des requêtes lentes est enregistré, il ne sera enregistré dans le journal qu'après avoir attendu la fin de son exécution.

    Nous pouvons utiliser show processlist pour afficher le thread exécutant SQL.
  • Exécutez à nouveau l'instruction suivante et utilisez le champ du compte d'index :

    SELECT name from user_info_large ORDER BY name desc limit 0,100000;
    Copier après la connexion

    Affichez le journal des requêtes lentes et il n'est pas enregistré.
  • Utilisez maintenant expliquer pour visualiser l'exécution des instructions SQL :

    # Time: 2022-09-26T13:44:18.405459Z
    # User@Host: root[root] @  [ip]  Id:  1893
    # Query_time: 10.162999  Lock_time: 0.000113 Rows_sent: 100000  Rows_examined: 2100000
    SET timestamp=1664199858;
    SELECT name from user_info_large ORDER BY name desc limit 0,100000;
    Copier après la connexion

    L'analyse est la suivante :
  • Résumé et partage des idées doptimisation des requêtes lentes MySQL

    可以看到没有使用到索引,type 为 ALL 表示全表扫描,效率最差,并且 Extra 也是外部排序。

    再看看这条 SQL 语句:

    explain SELECT account from user_info_large ORDER BY account desc limit 0,100000;
    Copier après la connexion

    分析情况如下:

    Résumé et partage des idées doptimisation des requêtes lentes MySQL

    type 为 index,使用了索引,使用的索引字段为 account,Extra 显示为使用索引排序。

    因此,在实际开发中,我们可以针对慢查询的 SQL,使用 explain 分析语句,根据分析情况以及索引的设计,重新设计 SQL 语句,让 SQL 语句尽量走索引,走合适的索引。

    5 优化器与索引

    在执行 SQL 时,MySQL 的优化器会根据情况选择索引,但并不能保证其执行时间一定最短,我们可以根据实际情况使用 force key (index) 让 SQL 语句强制走某个索引。

    例如,以下语句执行后,key 字段为 account,并没有走主键索引。

    explain SELECT count(id) from user_info_large;
    Copier après la connexion

    Résumé et partage des idées doptimisation des requêtes lentes MySQL

    如果使用 force key,就可以强制令语句走主键索引。

    explain SELECT count(id) from user_info_large force key (PRIMARY);
    Copier après la connexion

    Résumé et partage des idées doptimisation des requêtes lentes MySQL

    6 总结

    在项目中如果发现部分 SQL 语句执行缓慢,等待查询时间长,可以考虑优化慢查询,具体思路为:

    • 通过慢查询日志定位 SQL

    • 使用 explain 分析 SQL

    • 修改 SQL,令其走合适的索引

     在使用 explain 时,我们主要关注这些字段:

    • type

    • key

    • Extra

    在编写 SQL 使用索引的时候,我们尽量注意一下规则:

    • 模糊查询不要使用通配符 % 开头,例如 like '%abc'

    • 使用 or 关键字时,两边的字段都要有索引。或者使用 union 替代 or

    • 使用复合索引遵循最左原则

    • 索引字段不要参加表达式运算、函数运算

    推荐学习:mysql视频教程

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

MySQL: la facilité de gestion des données pour les débutants MySQL: la facilité de gestion des données pour les débutants Apr 09, 2025 am 12:07 AM

MySQL convient aux débutants car il est simple à installer, puissant et facile à gérer les données. 1. Installation et configuration simples, adaptées à une variété de systèmes d'exploitation. 2. Prise en charge des opérations de base telles que la création de bases de données et de tables, d'insertion, d'interrogation, de mise à jour et de suppression de données. 3. Fournir des fonctions avancées telles que les opérations de jointure et les sous-questionnaires. 4. Les performances peuvent être améliorées par l'indexation, l'optimisation des requêtes et le partitionnement de la table. 5. Prise en charge des mesures de sauvegarde, de récupération et de sécurité pour garantir la sécurité et la cohérence des données.

MySQL: Concepts simples pour l'apprentissage facile MySQL: Concepts simples pour l'apprentissage facile Apr 10, 2025 am 09:29 AM

MySQL est un système de gestion de base de données relationnel open source. 1) Créez une base de données et des tables: utilisez les commandes CreateDatabase et CreateTable. 2) Opérations de base: insérer, mettre à jour, supprimer et sélectionner. 3) Opérations avancées: jointure, sous-requête et traitement des transactions. 4) Compétences de débogage: vérifiez la syntaxe, le type de données et les autorisations. 5) Suggestions d'optimisation: utilisez des index, évitez de sélectionner * et utilisez les transactions.

Comment ouvrir phpmyadmin Comment ouvrir phpmyadmin Apr 10, 2025 pm 10:51 PM

Vous pouvez ouvrir PHPMYADMIN via les étapes suivantes: 1. Connectez-vous au panneau de configuration du site Web; 2. Trouvez et cliquez sur l'icône PHPMYADMIN; 3. Entrez les informations d'identification MySQL; 4. Cliquez sur "Connexion".

Comment créer Navicat Premium Comment créer Navicat Premium Apr 09, 2025 am 07:09 AM

Créez une base de données à l'aide de NAVICAT Premium: Connectez-vous au serveur de base de données et entrez les paramètres de connexion. Cliquez avec le bouton droit sur le serveur et sélectionnez Créer une base de données. Entrez le nom de la nouvelle base de données et le jeu de caractères spécifié et la collation. Connectez-vous à la nouvelle base de données et créez le tableau dans le navigateur d'objet. Cliquez avec le bouton droit sur le tableau et sélectionnez Insérer des données pour insérer les données.

MySQL et SQL: Compétences essentielles pour les développeurs MySQL et SQL: Compétences essentielles pour les développeurs Apr 10, 2025 am 09:30 AM

MySQL et SQL sont des compétences essentielles pour les développeurs. 1.MySQL est un système de gestion de base de données relationnel open source, et SQL est le langage standard utilisé pour gérer et exploiter des bases de données. 2.MySQL prend en charge plusieurs moteurs de stockage via des fonctions de stockage et de récupération de données efficaces, et SQL termine des opérations de données complexes via des instructions simples. 3. Les exemples d'utilisation comprennent les requêtes de base et les requêtes avancées, telles que le filtrage et le tri par condition. 4. Les erreurs courantes incluent les erreurs de syntaxe et les problèmes de performances, qui peuvent être optimisées en vérifiant les instructions SQL et en utilisant des commandes Explication. 5. Les techniques d'optimisation des performances incluent l'utilisation d'index, d'éviter la numérisation complète de la table, d'optimiser les opérations de jointure et d'améliorer la lisibilité du code.

Comment créer une nouvelle connexion à MySQL dans Navicat Comment créer une nouvelle connexion à MySQL dans Navicat Apr 09, 2025 am 07:21 AM

Vous pouvez créer une nouvelle connexion MySQL dans NAVICAT en suivant les étapes: ouvrez l'application et sélectionnez une nouvelle connexion (CTRL N). Sélectionnez "MySQL" comme type de connexion. Entrez l'adresse Hostname / IP, le port, le nom d'utilisateur et le mot de passe. (Facultatif) Configurer les options avancées. Enregistrez la connexion et entrez le nom de la connexion.

Comment récupérer les données après que SQL supprime les lignes Comment récupérer les données après que SQL supprime les lignes Apr 09, 2025 pm 12:21 PM

La récupération des lignes supprimées directement de la base de données est généralement impossible à moins qu'il n'y ait un mécanisme de sauvegarde ou de retour en arrière. Point clé: Rollback de la transaction: Exécutez Rollback avant que la transaction ne s'engage à récupérer les données. Sauvegarde: la sauvegarde régulière de la base de données peut être utilisée pour restaurer rapidement les données. Instantané de la base de données: vous pouvez créer une copie en lecture seule de la base de données et restaurer les données après la suppression des données accidentellement. Utilisez la déclaration de suppression avec prudence: vérifiez soigneusement les conditions pour éviter la suppression accidentelle de données. Utilisez la clause WHERE: Spécifiez explicitement les données à supprimer. Utilisez l'environnement de test: testez avant d'effectuer une opération de suppression.

Comment exécuter SQL dans Navicat Comment exécuter SQL dans Navicat Apr 08, 2025 pm 11:42 PM

Étapes pour effectuer SQL dans NAVICAT: Connectez-vous à la base de données. Créez une fenêtre d'éditeur SQL. Écrivez des requêtes ou des scripts SQL. Cliquez sur le bouton Exécuter pour exécuter une requête ou un script. Affichez les résultats (si la requête est exécutée).

See all articles