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

Symfony PHP Discussion :

[Symfony] Doctrine, mapper plusieurs champs d'une table a un tableau d'une entité [2.x]


Sujet :

Symfony PHP

  1. #1
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2012
    Messages
    73
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Avril 2012
    Messages : 73
    Points : 74
    Points
    74
    Par défaut [Symfony] Doctrine, mapper plusieurs champs d'une table a un tableau d'une entité
    Bonjour

    Voilà mon nouveau problème, et oui j'aime me compliquer la vie

    J'ai dans une vue SQL déjà créer des champs comme ci dessous :
    - code_1
    - code_2
    - code_3
    - name_1
    - name_2
    - name_3

    Je ne peux pas modifier cette vue, et elle st utilisé dans ce sens pour des raisons d'optimisations.
    Bref :p

    Dans mon entité, j'aimerai avoir un tableau (ou deux) plutôt que d'avoir 6 propriétés.
    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    ...
     /**
      * ORM\????
      */
     protected $arrCode;
     /**
      * ORM\????
      */
     protected $arrName;
    ...
    Seulement je n'ai aucune idée de comment m'y prendre.
    Quelqu'un pourrait m'aider, m'aiguiller ?
    Merci Beaucoup

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    t'as rien mettre à mettre à ce niveau (aucune annotations)

    c'est dans les méthodes que tout se passe

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    public function getCodes()
    {
        return array($this->code1, $this->code2, $this->code3);
    }
     
    public function getNames()
    {
        return array($this->name1, $this->name2, $this->name3);
    }

  3. #3
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2012
    Messages
    73
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Avril 2012
    Messages : 73
    Points : 74
    Points
    74
    Par défaut
    Merci de tes réponse rapides
    Je n'y avais pas pensée, merci
    Mais il n'y a donc aucun moyen de faire le mapping en amont ?

  4. #4
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    Citation Envoyé par Teudjy Voir le message
    Merci de tes réponse rapides
    Je n'y avais pas pensée, merci
    Mais il n'y a donc aucun moyen de faire le mapping en amont ?
    Non, c'est à toi de bien faire tes vues avec des jointures

  5. #5
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2012
    Messages
    73
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Avril 2012
    Messages : 73
    Points : 74
    Points
    74
    Par défaut
    Ce n'est pas moi qui ai créé ces vues, et elles ont été créées comme ca pour des raisons spécifiques. Il est vrai qu'avec deux tables avec une jointure serait plus simple (une collection d'une autre entité et c'est partit ).
    Mais disons que je pensais qu'il était possible de changer le comportement de symfony2, de surcharger une méthodes, une action, .... afin de choisir comment je récupère une entité.
    C'est donc impossible ?

  6. #6
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    non pas possible, après si ta vue est dynamique tu peux utiliser Reflection pour récupérer les propriétés mais bon ...

  7. #7
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2012
    Messages
    73
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Yvelines (Île de France)

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

    Informations forums :
    Inscription : Avril 2012
    Messages : 73
    Points : 74
    Points
    74
    Par défaut
    Ok, merci de tes réponses
    Je me débrouillerai avec ca

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 29/05/2015, 14h29
  2. MAJ Champs d'une table selon sa valeur et une table de correspondance
    Par eduardo9231 dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 26/06/2012, 10h53
  3. Réponses: 2
    Dernier message: 31/03/2011, 11h22
  4. Réponses: 2
    Dernier message: 17/01/2010, 18h09
  5. Réponses: 3
    Dernier message: 15/10/2008, 09h24

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