如何在jpql中选择列表元素的属性

时间:2018-03-20 09:53:51

标签: java sql maven java-ee jpql

我有一个Project实体,包含其创建者列表

public class Project implements Serializable { @ManyToMany private List<Creator> creator;

我需要一个带参数创建者ID的方法,返回该创建者创建的项目列表,这是我的想法

 public List<Project> MyOwnProjects(int idcreator){
String jpql= "select p from Project p where p.creator.get(i).getCode()= :idcreator";

Query query= em.createQuery(jpql);
query.setParameter("idcreator", idcreator);     
return (List<Project>)query.getResultList();
} 

此查询当然无效,我该怎么做?

1 个答案:

答案 0 :(得分:1)

除非你不能修改映射,否则我会反过来做:在你的Creator实体中添加一个@ManyToMany关联(使用MappedBy),然后就像这样(我的JPQL很生疏)

"select p from creator left join fetch creator.project p where creator.id = :idcreator "