Je objets:Jpa requête EJBQL par la propriété de la liste
PersenInfo : (long id,String name, String lastName,String email)
AnsMsg : (long id,PersenInfo fromPersoninfo,String theMsg)
Person : (PersonInfo personInfo, List<AnsMsg> msgs)
person.hbm ressemblent à ceci:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated May 4, 2012 2:48:41 PM by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<class name="Entities.Person" table="PERSON">
<id name="id" type="long">
<column name="ID" />
<generator class="increment" />
</id>
<many-to-one name="personInfo" class="Entities.PersonInfo" cascade="all" not-null="false" lazy="false"/>
<property name="_pass" type="java.lang.String" access="field" lazy="false">
<column name="_PASS" />
</property>
<property name="_IsConnect" type="int" access="field" lazy="false">
<column name="_ISCONNECT" />
</property>
<property name="c2dmId" type="java.lang.String" lazy="false">
<column name="C2DMID" />
</property>
<property name="lastSeen" type="long" lazy="false">
<column name="LASTSEEN" />
</property>
<list name="msgList" inverse="false" table="ANSMSG" lazy="false" >
<key column="parent_id" />
<index column="idx" />
<one-to-many class="msg.AnsMsg" />
</list>
</class>
</hibernate-mapping>
maintenant j'essayer d'obtenir toute la liste AnsMsg
que fromPerson = 6 et tous AnsMsg
que parent_id = 3;
comment ma requête devrait-elle ressembler? ( je veux dire quelque chose comme ceci:
"from AnsMsg ansMsg where ansMsg.fromPerson.id='6' or ansMsg.parent_id='6'"
bien sûr cette requête n'a pas supposé travailler .. )
ce que mon sosie de données:
merci en avance.
Il n'y a pas de parent_id dans votre description de l'entité AnsMsg. Et comme vous l'avez dit vous-même, vous recherchez les instances AnsMsg pour lesquelles 'ansMsg.fromPerson.id = 6', alors pourquoi avez-vous' ansMsg.fromPerson = '6'' dans votre requête? –