如何在jpql中选择列表元素的属性
Posted
技术标签:
【中文标题】如何在jpql中选择列表元素的属性【英文标题】:How to select an attribute of a list elements in jpql 【发布时间】:2018-08-29 01:54:57 【问题描述】:我有一个项目实体,其中包含其创建者的列表,
public class Project implements Serializable
@ManyToMany
private List<Creator> 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】:除非你不能修改映射,否则我会这样做:在你的 Creator 实体中添加一个 @ManyToMany 关联(使用 MappedBy),然后像这样(我的 JPQL 很生锈)
"select p from creator left join fetch creator.project p where creator.id = :idcreator "
【讨论】:
以上是关于如何在jpql中选择列表元素的属性的主要内容,如果未能解决你的问题,请参考以下文章
JPQL如何总结孩子的给定属性并获取这些孩子避免n + 1个选择?