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

NHibernate Discussion :

[Nhibernate] mapping one-to-one join left impossible


Sujet :

NHibernate

  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2010
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 55
    Points : 49
    Points
    49
    Par défaut [Nhibernate] mapping one-to-one join left impossible
    Bonjour,

    Je rencontre un nouveau problème. NHibernate se comporte bizarrement sur un mapping one-to-one.

    j'ai déclaré la relation comme suit

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
      <class name="info" table="Info"...> 
     
          <id name="Id" type="System.Int32" unsaved-value="null">
            <column name="INV_ID" />
          </id>
     
           ....
     
          <one-to-one name="ExInfo" class="ExInfo" fetch="join" outer-join="true" >             
          </one-to-one>
     
      </class>
     
      <!-- Mappings for table 'ExInfo' -->
      <class name="ExInfo" table="ExInfo" lazy="false">
     
          <!-- Identity mapping -->
          <id name="Id" type="System.Int32" unsaved-value="null">
            <column name="INV_ID" />
          </id>
     
          <!-- Simple mapping -->
          <property name="info1" column="info1"/>
      </class>
    Je souhaites faire un left join entre les deux tables mais Nhibernate me génère un select a la place.
    Du coup, lorsque je n'ai pas d'enregistrement dans ExInfo en relation avec celui de la table la table Info, une sélection ne retourne rien. Normal.

    Comme faire pour "forcer" un left outer joint ?

    Merci de votre aide

  2. #2
    Membre du Club
    Homme Profil pro
    Inscrit en
    Septembre 2010
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 55
    Points : 49
    Points
    49
    Par défaut
    Trouvé !

    En fait le mapping gère le type de jointure. Sur une requête simple cela marche parfaitement. MAIS si on fait une requête ICriteria avec une condition sur la jointure alors cette derniere force le type de jointure.

    Pour conserver le left outer join il faut donc quelque chose du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    criteres.CreateAlias("ExInfo", "ex", NHibernate.SqlCommand.JoinType.LeftOuterJoin);
    "

    et voilou.

    @+

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

Discussions similaires

  1. Problème de mapping Foreign key one-to-one
    Par chady dans le forum Hibernate
    Réponses: 3
    Dernier message: 20/06/2010, 23h35
  2. <one-to-one> dans un <join>
    Par philippe@llc dans le forum Hibernate
    Réponses: 2
    Dernier message: 30/03/2007, 10h50
  3. mapping de deux one-to-many
    Par emilie_caroline dans le forum Hibernate
    Réponses: 11
    Dernier message: 30/11/2006, 16h58
  4. [Hibernate]Mapping relation one-to-one
    Par K-Kaï dans le forum Hibernate
    Réponses: 9
    Dernier message: 23/06/2006, 16h02
  5. [Hibernate] Mapping de one to one ?
    Par Limod dans le forum Hibernate
    Réponses: 4
    Dernier message: 07/06/2006, 10h06

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