如何在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个选择?

JPQL 根据孙属性选择实体

如何在 JPQL 中选择随机 10 条记录?

如何在 Spring JpaRepository 中使用 JPQL 选择组中的最新记录?

使用 JPQL/HQL 在 JPA 中订购连接获取的集合

如何在 JPQL 查询中从 LocalDate 获取月份?