8 requêtes SQL pour optimiser WordPress.

A travers 8 requêtes SQL, nous allons voir comment optimiser WordPress et la base MySQL du CMS afin de le rendre plus véloce. Attention avant toutes opérations sur la base MySQL vous devez avoir réalisé une sauvegarde complète.

Effacer les spams de la table des commentaires.

Si comme moi vous recevez beaucoup de spam, les tables wp_comments et wp-commentmeta peuvent grossir à vue d’œil. Voyons comment effectuer quelques optimisations sur ces tables.

Toutes les requêtes seront exécutées depuis l’interface phpmyadmin dans l’onglet SQL.

Effacer les spams de la table des commentaires grâce à SQL

Afin de faire un petit bilan à la fin des optimisations voici les statistiques de ma base avant :

Taille de la base de données MySQL avant les optimisations

DELETE FROM wp_comments WHERE comment_approved = "spam"

Effacer les spams de la table des commentaires WordPress grâce à SQL

Effacer les commentaires que vous avez refusé.

DELETE FROM wp_comments WHERE comment_approved = "0"

Effacer les commentaires WordPress que vous avez refusé avec une requete SQL

Effacer toutes les méta-valeurs des commentaires qui n’existent plus.

DELETE FROM wp_commentmeta WHERE comment_id NOT IN (SELECT comment_id FROM wp_comments)

Effacer toutes les méta-valeurs des commentaires WordPress qui n'existent plus avec SQL.

Effacement de toutes les valeurs temporaires (Valeur %transient%).

Depuis les dernières versions de WordPress, celui-ci utilise un mécanisme de cache se basant sur la table wp-options. Cette méthode est pratique mais elle charge inutilement la table des options avec des valeurs qui ne disparaissent jamais.

Effacement de toutes les valeurs temporaires (Valeur %transient%) de WordPress avec SQL

Effacer les versions des articles.

Le système de restauration des articles est très avantageux, mais même si on édite très rarement des articles publiés, les anciennes versions restent dans la base.

DELETE FROM wp_posts WHERE post_type = "revision"

Effacer les versions des articles de WordPress avec SQL

Effacer les sauvegardes automatiques de WordPress.

DELETE FROM wp_posts WHERE post_status = "auto-draft"

Effacer les sauvegardes automatiques de WordPress avec SQL

Effacer complètement les enregistrements Askimet.

Une fois activée, l’extension Askimet remplit vite la table wp_commentmeta (un commentaire posté entraine trois enregistrements dans la table wp_commentmeta). Il est donc indispensable de lancer régulièrement la requête ci-dessous.

DELETE FROM `wp_commentmeta` WHERE `meta_key` LIKE "Akismet%"

Effacer complètement les enregistrements Askimet de WordPress avec SQL

Optimiser les tables la base MySQL de WordPress.

Maintenant que toutes les lignes superflues sont supprimées, vous devez optimiser vos tables.

Toujours sous PhpMyAdmin, revenez à l’onglet Structure

Optimiser les tables de la base MySQL de WordPress.

Ensuite aller en bas de page et cliquer sur Tout cocher (cela sélectionne toutes les tables de votre base).

Optimiser les tables de la base MySQL de WordPress.

Puis dans la liste déroulante situé en face, sélectionner Optimiser la table puis cliquer sur Exécuter.

Optimiser les tables de la base MySQL de WordPress.

A bout de quelques secondes toutes vos tables sont optimisées.

Optimiser les tables de la base MySQL de WordPress.

Maintenant faisons un petit bilan de ces optimisations :

Optimiser les tables de la base MySQL de WordPress.

Au niveau des enregistrements 2396 lignes en moins et surtout au niveau taille moins 7 Mo, c’est ma sauvegarde qui va être contente.

Quelles sont les autres optimisations possibles ?

Personne n’aime attendre pendant qu’une page se charge. C’est pour cette raison qu’il est essentiel d’optimiser son site, pour offrir la meilleure expérience utilisateur possible. Selon les chiffres fournis par Google lui-même, si votre page web met

  • Entre 1 et 3 secondes, le taux d’abandon est de 32 %
  • Entre 1 et 5 secondes, le taux grimpe à 90 %
  • Une seconde supplémentaire et vous avez 106 % d’abandon
  • Si elle met plus de 10 secondes, le taux grimpe à 123 %.

Google a d’ailleurs très récemment mis en place des Core Web Vitals, qui s’occupent non pas du contenu de votre site, mais de 3 aspects techniques, à savoir :

  • Largest Contentful Paint (LCP) : ici, il va chercher à savoir quel est le temps de chargement du plus grand élément.
  • First Input Delay (FID) : il sera question de connaître quand les utilisateurs interagissent avec le site Web.
  • Cumulative Layout Shift (CLS ): cette fois, c’est la mise en page qui est analysée (change-t-elle au fur et à mesure que la page se charge ?)

Bien entendu, et même si vous suivez nos conseils pour nettoyer votre base de données, ça ne suffira très certainement pas à améliorer de façon significative la note globale de votre site. Il est donc plus que conseillé de faire appel à des sociétés, qui proposent les prestations d’optimisation WordPress de Webperformer, pour vous éviter de perdre un temps précieux.

Si vous connaissez d’autre requête pour optimiser la base MySQL de WordPress je suis preneur, laisser un commentaire ou utiliser le formulaire de contact.

Signature manuelle Guillaume

1 potin

  1. Merci pour le partage de ces astuces. Il est possible d’optimiser toutes les bases de données d’un serveur en utilisant mysqlcheck, qui est largement plus rapide notamment avec un grand volume de données.

    La commande :
    mysqlcheck -Aos

    ou mysqlcheck -u root -Aos -p
    pour s’identifier manuellement en tant que root

Laisser un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *