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.