Vous n'êtes pas identifié(e).
- Contributions : Récentes | Sans réponse
#1 19/01/2015 10:45:49
- Okiuy
- Membre
Mise à jour structure d'une base sur le modèle d'une autre
Bonjour,
brève présentation, je fait partie d'une équipe de développement dans une société éditrice de logiciel web.
Coté client, nous utilisons Sencha, et coté serveur, Java, sous un tomcat, et PostgreSQL en SGBDD sur un serveur linux.
Chacun de nos clients possède sa base de données propre.
L'application étant en perpétuelle évolution, les modifications de structure de base de données sont notées dans un fichier texte, qui est passé sur la base du client au moment ou ce dernier se connecte pour la première fois après la mise en prod d'une nouvelle version de l'application.
Ma question : existe t-il un utilitaire, qui, en ligne de commande sous linux, permettrait de mettre a jour une base (ou plusieurs) selon une base "modèle" ?
ça existe pour la création de base, mais pour une mise a jour de structure ? ...
Merci
Hors ligne
#2 19/01/2015 15:04:13
- MitsuTomoe
- Membre
Re : Mise à jour structure d'une base sur le modèle d'une autre
Bonjour,
il y a 3 ans j’ai utilisé avec succès apgdiff : Another PostGreSQL Diff Tool .
Il permet de comparer 2 exports et générer un script pour rendre la structure des 2 bases identiques.
Je ne sais pas s’il est toujours d’actualité, mais ça vaut sûrement la peine d’y jeter un oeil.
Alex Leguevaques
Hors ligne
#3 19/01/2015 18:29:54
- gleu
- Administrateur
Re : Mise à jour structure d'une base sur le modèle d'une autre
Généralement, on utilise un outil (comme apgdiff ou check_postgres) pour connaître les différences de schémas. Puis on crée le script, on le teste, et enfin on l'utilise en prod. Attendez-vous à des surprises si l'outil modifie automatiquement le schéma d'une base par rapport à une autre base. Ne serait-ce que si vous pointez la mauvaise base, ça risque d'être rigolo. Ça ne pardonnera pas, et ça résultera en des suppressions de données peu amusantes à expliquer au client.
Guillaume.
Hors ligne