Bonjour
je dois réoudre un probleme sur une application que je dois coder sous symfony, une application en apparence il s'agit essentiellement de faire de la saisie de données afin de générer des statistiques. Et donc pour cela on a différentes tables qui sont reliées en général à un formulaire qui va récolter les informations nécessaire pour les insérer dans cette table.
Le petit piege sur ce projet c'est que les utilisateurs finaux souhaitent pouvoir ajouter des champs dans les différents formulaires si ils ressentent le besoin de récolter nouveaux types d'informations. Exemple tout bete: on récolte les informatiosn sur les employés de l'entreprise à travers un formulaire qui comporte un champ téléphone fixe et il s'avert qu'on veuille ajouter un champ téléphone mobile. Jusque là so far so good, cependant afin de sauvegarder cette nouvelle info en base de données, typiquement on va devoir ajouter une nouvelle colonne dans la table Employée de notre base...
L'application étant developpée avec symfony, c'ets donc là se pose la tuile car on vient de modifier le modele de données et donc il faut régénérer le modele via doctrine ou propel en ligne de commande. Il n'est evidemment pas question de livrer au client une appli sur laquelle il va devoir faire des lignes de commande pour générer des classes du modele de données.
ma question: Comment structurer ma base de données pour que je puisse faire les modifications attendues par mon client sans passer passer par l'ajout d'une nouvelle colonne et donc une modification du modele de données necessitant une régénration des classes par Doctrine ou propel?
Exemple de tables: Produits (prix, description, nom), Magasins(adresse, type)
exemples formulaire: saisie info produits, saisie info magasin
Exemple modification: on veut pouvoir saisir et enregistrer en base le nom du fabriquant du produit, et l'on voudrai pouvoir saisir et enregistrer en base le nom du gérant du magasin. Comment pourrai t on structuré la base de donnée pour qu'elle puisse sous symfony 1.2 permettre ce type d'opération: ajout de champ formulaire et possibilité d'enregistrer les nouvelles saisies sans moidifier la structure de la BDD?
Partager