如何select jpql中列表元素的属性

How to select an attribute of a list elements in jpql

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

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();
} 

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

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

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