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

Hibernate Java Discussion :

[Criteria] Relation one-to-many


Sujet :

Hibernate Java

  1. #1
    Membre régulier Avatar de dedeloux
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 104
    Points : 75
    Points
    75
    Par défaut [Criteria] Jointure avec one-to-many et many-to-one
    Bonjour, je rencontre un problème avec la création d'une jointure avec des criteria.
    J'ai trois tables : user, site, et user_site (qui est la table de correspondance entre user et site).
    Un user peut appartenir à plusieurs sites.

    Le mapping hibernate de mes classes est le suivant :
    Table User
    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
     
    <hibernate-mapping>
        <class name="User" table="user">
     
        <id name="id" type="integer">
           <generator class="increment"/>       
        </id>
     
        <set name="userSites">
        	<key column="user"/>
        	<one-to-many class="UserSite"/>
        </set>
     
    </class>
    </hibernate-mapping>
    Table Site
    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
     
    <hibernate-mapping>
        <class name="Site" table="sites">
     
        <id name="id" type="integer">
           <generator class="increment"/>       
        </id>
     
        <set name="siteUsers">
        	<key column="site"/>
        	<one-to-many class="UserSite"/>
        </set>
     
    </class>
    </hibernate-mapping>
    Table user_site
    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
     
     
    <hibernate-mapping>
        <class name="UserSite" table="user_site">
     
        <id name="id" type="int">
          <generator class="increment"/>        
        </id>
     
    	<many-to-one name="site" class="Site">
    	  <column name="site"/>
    	</many-to-one>
     
    	<many-to-one name="user" class="User"> 
    	  <column name="user"/>
    	</many-to-one>
     
     </class>
    </hibernate-mapping>
    Je précise que j'ai des attributs autres que les clés étrangères site et user dans ma table user_site, ce qui explique pourquoi je ne passe pas par une relation many-to-many.

    Création de mon criteria :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Criteria criteria = session.createCriteria(User.class);
    criteria.createCriteria("userSites").add(Restrictions.eq("site", site));
    criteria.list();
    Lorsque j'éxécute le tout, j'ai l'erreur suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    org.hibernate.PropertyAccessException: IllegalArgumentException occurred calling getter of Site.id
    Je ne trouve pas de solution. Le getter pour la propriété "id" est correctement défini dans ma classe Site. l'id dans ma classe Site est un Integer et le "site" que je passe en paramètre dans mon criteria est aussi un Integer.

    Voilà, si quelqu'un a une idée ou des conseils sur une meilleure façon de faire, je suis preneuse.

    Merci par avance.

  2. #2
    Membre régulier Avatar de dedeloux
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 104
    Points : 75
    Points
    75
    Par défaut
    Merci à tous ceux qui ont lu mon post, j'ai fini par trouver mon erreur :
    Dans mon DAO, je ne faisais pas la bonne requête :

    Je devais écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    criteria.createCriteria("userSites").createCriteria("site").add(Restrictions.eq("id", site));
    Au lieu de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    criteria.createCriteria("userSites").add(Restrictions.eq("site", site));

Discussions similaires

  1. Relation one-to-many qui ne se crée pas
    Par Julien G dans le forum Hibernate
    Réponses: 4
    Dernier message: 01/08/2007, 18h02
  2. Réponses: 4
    Dernier message: 18/06/2007, 08h30
  3. [Hibernate] Relation one to many
    Par BRAUKRIS dans le forum Hibernate
    Réponses: 2
    Dernier message: 23/08/2006, 11h51
  4. [hibernate] relation one-to-many avec plusieurs clés
    Par seb_fou dans le forum Hibernate
    Réponses: 6
    Dernier message: 16/03/2006, 14h47
  5. [EJB2.1 Entity] [CMR] Relation One to Many
    Par hamed dans le forum Java EE
    Réponses: 2
    Dernier message: 31/12/2003, 14h26

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