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

Doctrine2 PHP Discussion :

Probleme avec une relation ManytoOne


Sujet :

Doctrine2 PHP

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 51
    Points : 28
    Points
    28
    Par défaut Probleme avec une relation ManytoOne
    Bonjour a tous,

    Je suis bloqué sur un relation ManytoOne Bidirectionelle, Est ce que j'ai fait une erreur ?

    voici mon code :

    Entité Domain

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    /**
    * @ORM\OneToMany(targetEntity="Languageavailable", mappedBy="domain")
    */    
    protected $languageAvailable;
    Entité Languageavailable

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    /**
         * @var \domain
         *
         * @ORM\ManyToOne(targetEntity="Domain", inversedBy="languageAvailable")
         * @ORM\JoinTable(name="Domain")
         */
        protected $domain;
    Puis pour récupérer mes domaines j'effectue ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $Domain = $this->doctrine->getRepository('monbudle:Domain')
                                           ->findall();
    Cependant quand je regarde la requete qui est faite aucune jointure n'est faite avec la table Languageavailable.

    Puis si je fait ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    foreach($Domain as $keywl => $valuewl){
                             $LanguageAvailable = $valuewl->getLanguageAvailable();
     
                              echo " Nom : {$valuewl->getName()} Domaine : {$valuewl->getDomain()}";
                                foreach($LanguageAvailable as $key => $value){
                                    echo $value->getIsdefault();
                                }       
                        }
    J'ai deux autres requetes qui sont effectuées, chacunes pour aller prendre les languagesdisponibles de chaques domaines. Il ne devrait pas normalement me faire une seule requete avec une jointure entre les deux tables ?

    Je comprend pas trop, merci pour votre aide.

    Decad7

  2. #2
    Membre averti Avatar de Njörd
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    190
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 190
    Points : 390
    Points
    390
    Par défaut
    Bonjour decad7,

    Je crois que pour ta relation ManyToOne, il manque le mappage des colonnes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    /**
    * @var \domain
    *
    * @ORM\ManyToOne(targetEntity="Domain", inversedBy="languageAvailable")
    * @ORM\JoinColumn(name="entry_id", referencedColumnName="id")
    * @ORM\JoinTable(name="Domain") <-- A SUPPRIMER ???
    */
        protected $domain;

Discussions similaires

  1. Réponses: 3
    Dernier message: 01/08/2012, 19h59
  2. Réponses: 1
    Dernier message: 17/10/2010, 19h08
  3. probleme avec une relation OneToOne
    Par aniss77 dans le forum JPA
    Réponses: 1
    Dernier message: 01/04/2010, 22h07
  4. Réponses: 1
    Dernier message: 25/09/2006, 10h18
  5. probleme avec une division par zéro
    Par jcharleszoxi dans le forum Langage SQL
    Réponses: 2
    Dernier message: 26/03/2003, 18h14

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