jeudi 20 mars 2014

14 - Sauvegarde d'une base de données

0 commentaires
Il est bien utile de pouvoir sauvegarder facilement sa base de données, et très important de la sauvegarder régulièrement. Une mauvaise manipulation (ou un méchant pirate :pirate: s'il s'agit d'un site web) et toutes les données peuvent disparaître. MySQL dispose donc d'un outil spécialement dédié à la sauvegarde des données sous forme de fichiers texte : mysqldump.
Cette fonction de sauvegarde s'utilise à partir de la console. Vous devez donc être déconnectés de MySQL pour la lancer. Si c'est votre cas, tapez simplement exit
Vous êtes maintenant dans la console Windows (ou Mac, ou Linux).
La manière classique de faire une sauvegarde d'une base de données est de taper la commande suivante :
mysqldump -u user -p --opt nom_de_la_base > sauvegarde.sql

Décortiquons cette commande.
  • mysqldump : il s'agit du client permettant de sauvegarder les bases. Rien de spécial à signaler.
  • --opt : c'est une option de mysqldump qui lance la commande avec une série de paramètres qui font que la commande s'effectue très rapidement.
  • nom_de_la_base : vous l'avez sans doute deviné, c'est ici qu'il faut indiquer le nom de la base qu'on veut sauvegarder.
  • > sauvegarde.sql : le signe > indique que l'on va donner la destination de ce qui va être généré par la commande : sauvegarde.sql. Il s'agit du nom du fichier qui contiendra la sauvegarde de notre base. Vous pouvez bien sûr l'appeler comme bon vous semble.
Lancez la commande suivante pour sauvegarder elevage dans votre dossier courant (c'est-à-dire le dossier dans lequel vous étiez au moment de la connexion) :
mysqldump -u sdz -p --opt elevage > elevage_sauvegarde.sql

Puis, allez voir dans le dossier. Vous devriez y trouver un fichier elevage_sauvegarde.sql. Ouvrez-le avec un éditeur de texte.
Vous pouvez voir nombre de commandes SQL qui servent à la création des tables de la base de données, ainsi qu'à l'insertion des données. S'ajoutent à cela quelques commandes qui vont sélectionner le bon encodage, etc.
La base de données est donc sauvegardée. Notez que la commande pour créer la base elle-même n'est pas sauvée. Donc, si vous effacez votre base par mégarde, il vous faut d'abord recréer la base de données (avec CREATE DATABASE nom_base), puis exécuter la commande suivante (dans la console) :
mysql nom_base < chemin_fichier_de_sauvegarde.sql

Concrètement, dans notre cas :
mysql elevage < elevage_sauvegarde.sql

Ou, directement à partir de MySQL :
1USE nom_base;
2source fichier_de_sauvegarde.sql;
Donc :
1USE elevage;
2source elevage_sauvegarde.sql;

Leave a Reply