IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

conception pour une appli en POO : une classe par table ?


Sujet :

PHP & Base de données

  1. #1
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 378
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut conception pour une appli en POO : une classe par table ?
    Bonjour,

    je souhaite une confirmation avant de me lancer dans un travail qui va probablement prendre plusieurs jours.

    Je travaille sur une application que je développe en POO/MVC. Dans sa première version, j'avais une table SQL unique comportant plein de colonnes (pour une partie de l'application of course) et j'y faisais correspondre une classe unique du modèle.

    Par contre, j'ai revu la modélisation de l'appli et la table SQL unique est aujourd'hui décomposée en 7 tables (avec des clés étrangères)...

    Donc question sur la conception : est-il justifié de créer 7 classes dans le modèle ?

    Comme il s'agit d'une question de méthodologie, je doute de la nécessité de donner plus de détails. Merci de votre réponse.
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  2. #2
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 405
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 405
    Points : 4 841
    Points
    4 841
    Par défaut
    Bonjour,

    Pour répondre brièvement à ta question, ce ne sont pas les tables MYSQL qui détermineront le nombre de classes qu'il faut créer mais plutôt le rôle et le besoin de chaque classe.

    Supposons qu'on veut par exemple gérer les publications des utilisateurs dans le fil d'actualité et dans les groupes, et qu'on a deux tables pubs, et pubs_groupe (en supposant que la modélisation a été mal partie et qu'on ne veut plus ou on n'a pas le droit de modifier la structure de la base), dont la première représente les publications d'un utilisateur dans son fil d'actualité et la deuxième représente les publications dans (un/plusieurs) groupe(s).

    Une publication à besoin d'au moins 4 informations: un id, l'id de l'émetteur, le texte et la date, et si la publication doit représenter une pub_groupe, dans ce cas, elle devrait avoir besoin d'une info de plus qui est le id du groupe.

    Les colonnes de pubs sont : id_pub,id_emeteur,text_pub,date_pub et celles de pubs_groupe sont : id_pub,id_emeteur,text_pub,date_pub,id_groupe.

    Comme vous voyez, la seule différence entre les deux tables est la colonne id_groupe, dans ce cas il ne faut pas créer 2 classes pour chacune, mais il y'a deux possibilités ( sans l'utilisation d'une classe abstraite...):
    • Soit créer une seule classe Pubs qui gère les deux tables et ajouter une propriété private $typePub; afin de déterminer si c'est une simple pub ou une pub groupe :
      Code php : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      8
      9
       
      class Pub{
         private $idPub;
         private $idEmeteurPub;
         private $textPub;
         private $DatePub;
         private $typePub;
         /* Les setters et getters + constructeur */
      }
    • Soit d'utiliser une classe Pub dans laquelle vous mettez seulement les propriétés nécessaires d'une publication + 1 classe PubGroupe héritant de Pub qui contient une propriété de plus $typePub;
      Code php : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
       
      class Pub{
         private $idPub;
         private $idEmeteurPub;
         private $textPub;
         private $DatePub;
         /* Les setters et getters + constructeur */
      }
      class PubGroupe extends Pub{
          private $typePub;
         /* Les setters et getters + constructeur parent */
      }

  3. #3
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 222
    Points
    20 222
    Par défaut
    Comme le dit Toufik , il n'ya pas nécessairement de lien entre nombre de table et nombre de classe.
    Dans les faits c'est souvent le cas car la modélisation des données est souvent assez proche de la modélisation objet mais pas toujours.

    Typiquement les tables "utilitaires" qui permettent de faire le lien entre 2 tables ne sont généralement pas représentée par une classe.

    Bref il n'ya pas de règle universelle , ca dépend.
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 378
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Merci pour vos réponses.

    Citation Envoyé par Toufik83 Voir le message
    Pour répondre brièvement à ta question
    Qu'est-ce que ça doit être quand c'est pas bref
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Question de conception objet, une classe par table RDB
    Par callapa dans le forum Débuter avec Java
    Réponses: 0
    Dernier message: 14/01/2011, 10h55
  2. [PHP 5.2] Conception d'une classe de table de base de données
    Par anaranjado dans le forum Langage
    Réponses: 2
    Dernier message: 19/12/2009, 23h20
  3. [POO] Equivalent de getElementById mais pour une class ?
    Par boutmos dans le forum Général JavaScript
    Réponses: 19
    Dernier message: 29/04/2008, 10h19
  4. [POO] POO pour une classe PDO
    Par nabab dans le forum Langage
    Réponses: 2
    Dernier message: 07/08/2007, 23h58
  5. [POO] Plugins pour une classe ?
    Par PseudoCoder dans le forum Langage
    Réponses: 6
    Dernier message: 05/10/2006, 12h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo