Supprimer / limiter les révisions d’articles de WordPress

Les révisions d’articles permettent de restaurer à une date précise la sauvegarde du billet en question. Bien que très pratique, cette fonctionnalité finit par encombrer la base de données après de nombreux enregistrements.

N.B : avant d’opérer une quelconque modification dans votre base de données, je vous recommande fortement de visionner le podcast Sauvegarder automatiquement votre base de données MySQL.

Il est donc conseillé d’effacer les révisions d’articles. Toutefois, pour aller plus loin, nous allons faire en sorte que les X dernières soient conservées pour allier performances et sécurité.

#1 – Effacer toutes les révisions d’articles

Exécutez la requête SQL ci-dessous pour supprimer la totalité des versions d’articles. Après cette action, il vous sera impossible de restaurer l’un d’eux à une date antérieure.

DELETE a,b,c
FROM wp_posts a
LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)
LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)
WHERE a.post_type = 'revision';

#2 – Effacer les révisions en fonction d’une date

Pour ne garder que l’historique récent de vos articles, préférez cette requête. La dernière ligne indique une date que vous pouvez modifier ; en l’occurrence, le 1er janvier 2010. Avant celle-ci, toutes les sauvegardes seront supprimées.

DELETE a,b,c

FROM wp_posts a

LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)

LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)

WHERE a.post_type = 'revision'

AND a.post_date < '2010-01-01';

Pour aller plus loin

Il est possible de désactiver le versionning des articles. A l’aide de votre client FTP favori, connectez-vous à la racine de votre site WordPress puis ouvrez wp-config.php.

Ajoutez ensuite la ligne suivante :

define('WP_POST_REVISIONS', false);

En indiquant un chiffre à la place du paramètre false, vous limiterez le nombre de sauvegardes – à 5 dans cet exemple. Idéal pour un système optimisé et sécurisé

define('WP_POST_REVISIONS', 5);

Les révisions d’articles constituent un atout majeur de WordPress. Il n’est pas rare de devoir revenir en arrière après une modification malencontreuse. Entre performances SQL et niveau de risques, à vous de trouver un juste milieu !

Crédits photo : mookxi

Aurélien Denis est le fondateur du projet WordPress Channel proposant tutoriels et podcasts librement téléchargeables. En 2010, il fonde Neticpro, une agence Web spécialisée WordPress. Il est aussi co-fondateur du site Protuts.net (tutoriels PC/Mac/Linux) et community manager pour l’Imagine Cup 2011/2012, une compétition mondiale organisée par Microsoft.

27 commentaires

  1. Admettons que j’utilise :
    define(‘WP_POST_REVISIONS’, 5);

    Il me semble plutôt logique de supprimer les révisions >5, as tu une requête SQL en tête pour cette opération ?

  2. Ouf, j’ai enfin compris un truc après avoir cherché pendant des semaines : il ne faut pas mettre le code n’importe où dans le fichier wp-config sinon, au mieux, cela ne marche pas… au pire, tous mes articles et pages étaient passés à la poubelle !

    J’ai finalement placé le code avant les clefs d’authentification et c’est OK…

    • A-snowboard

      Juste un petit mot pour dire que tout a fonctionné pour moi !
      Mais comme le dit olivierC, il faut mettre le code avant les clef d’authentification. Sinon ça ne marche pas !

      Bonne soirée !

  3. PS : je parlais du code de désactivation des révisions…

  4. Merci pour ce tuto très clair. Résultat de ma requête : plus de 11,000 écritures supprimées.
    Je cherchais à faire ça depuis longtemps. Le ménage est fait.
    Merci.

  5. Merci du tuyau, j’ai pu alléger ma table wp_posts de 20 % :)

  6. Bonjour
    Impossible pour moi de trouver comment revenir sur une erreur. J’ai ajouter une photo a une galerie et puis après seule la dernière photo s’affiche (les autres ont disparues). C’a m’arrive souvent.
    A chaque fois il faut tout refaire car je ne sais pas comment revenir en arrière.
    ps: je suis nul en informatique et ne comprends pas les infos trop complexe.
    Si tu as la réponse, je te remercie à l’avance.
    Yann

  7. merci pour ce tutorial je vien de supprimer 10Mo de ma base de données merci beaucoup

  8. Merci pour cet article, il s’accorde bien avec celui sur la sauvegarde ! :-)

  9. Merci une fois de plus pour ses articles intéressent. Mais j’ai tenté cette requête mais à chaque fois j’ai une :
    Erreur SQL :

    ERREUR: erreur de syntaxe sur ou près de « a »
    LINE 1: DELETE a,b,c
    ^

    Dans l’instruction :
    DELETE a,b,c

    FROM wp_posts a

    LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id)

    LEFT JOIN wp_postmeta c ON (a.ID = c.post_id)

    WHERE a.post_type = ‘revision’

    AND a.post_date < '2012-09-17';

    je sais pas si ma base n'a pas un problème et il es arriver même que j'ai eu envie de recharger un backup suite à un problème sur le blog. Et j'ai toujours un message d'erreur. Tu n'aurais pas une piste..
    merci par avance

  10. Salut Aurélien,

    Merci de ces infos, j’utilise pour ma part dans le config:

    define(‘WP_POST_REVISIONS’, 2);
    define(‘EMPTY_TRASH_DAYS’, 3 );

    Sinon y a aussi WP-Optimize pour nettoyer et alléger la BDD ;)

  11. Bonjour Aurélien,

    Comment se passe la purge automatique des révisions après la mise en place de la variable « WP_POST_REVISIONS »?
    Est-elle rétroactif?

  12. ANais

    Bonjour,
    Utilisant la version 3.5.1 de WordPress, je ne vois pas les révisions d’articles. Est-ce à dire que WordPress supprime maintenant automatiquement les anciennes versions des articles (donc plus de besoin de passer par le code sql donné)?
    Merci

    • Vérifies dans le menu Options de l’écran situé en haut à droite de ta fenêtre pour vérifier que les révisions ne sont pas masquées car rien n’a changé dans le core de WordPress à ce sujet.

  13. ANais

    Bonjour,
    Effectivement les révisions étaient masquées. Merci.

  14. Anais

    Bonjour Bonjour,
    J’ai placé le code define(‘WP_POST_REVISIONS’, 2); dans mon fichier wp-config.
    Sur le test que je viens de faire en créant un article sur mon site, je vois bien que les deux dernières révisions restent affichées. Par contre, pour tous mes anciens articles (j’en ai certains avec des dizaines de révisions), il n’affichent pas les deux dernières révisions (mais tout encore). Faut-il faire autre chose pour les supprimer ?

  15. Anais

    C’est bon de mon côté.
    Comme dit dans mon comm précédent, j’ai placé le code define(‘WP_POST_REVISIONS’, 2); dans mon fichier wp-config, puis j’ai exécutée la requête pour supprimer les révisions et tout est bon. Merci

  16. Bonjour à tous,
    Quelle est la requête pour supprimer les révisions svp ?
    Merci par avance

Rétrolien pour cet article

  1. Sauvegardez et réinstallez la bdd de votre blog en moins de 15 minutes Conseils #Blogging
  2. Conseil de Liens 1, spécial #WordPress - Aventure Personnelle | Aventure Personnelle

Laisser un commentaire