Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 2 sur 2
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    septembre 2010
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : septembre 2010
    Messages : 53
    Points : 16
    Points
    16

    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 :
    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
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    septembre 2010
    Messages
    53
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : septembre 2010
    Messages : 53
    Points : 16
    Points
    16

    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 :
    criteres.CreateAlias("ExInfo", "ex", NHibernate.SqlCommand.JoinType.LeftOuterJoin);
    "

    et voilou.

    @+

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

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •