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

标签 java sql maven jakarta-ee 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 "

关于java - 如何在jpql中选择列表元素的属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49381037/

相关文章:

java - ASM 在解释器上合并两个值对象

python - 在django中选择过滤后的相关对象

mysql - 生日查询需要 SQL 帮助

java - 在泛型类中使用接口(interface)作为边界类型

java - Astyanax 中的 Cassandra CQL3 支持

java - 使用用户输入和 FileInputStream 创建文件并从该文件读取整数时遇到问题

sql - 如何使用 Django 中的单个查询集选择记录并更新它?

java - 无法在eclipse juno中创建maven项目

java - Linux 上的 IntelliJ 使用错误的依赖版本

java - 如何在maven项目中包含共享对象文件