我有一个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();
}
此查询当然无效,我该怎么做?
答案 0 :(得分:1)
除非你不能修改映射,否则我会反过来做:在你的Creator实体中添加一个@ManyToMany关联(使用MappedBy),然后就像这样(我的JPQL很生疏)
"select p from creator left join fetch creator.project p where creator.id = :idcreator "