首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JPA CriteriaQuery OneToMany

JPA CriteriaQuery OneToMany
EN

Stack Overflow用户
提问于 2012-02-25 23:40:45
回答 2查看 10K关注 0票数 8

我有两个具有OneToMany关系的实体。为了简单起见,让我们假设他们是学校和学生,具有从学校到学生的单向关系。我想要找到具有特定学生(具有特定年龄、姓名、ssn等的学生)的学校对象。我知道我可以为简单学校的属性创建一个简单的标准,如下所示(对于学校的名称,如下所示):

代码语言:javascript
复制
ParameterExpression<String> p = criteriaBuilder.parameter(String.class, "schoolName");
            criteria = criteriaBuilder.and(criteria, criteriaBuilder.like(schoolRoot.get("schoolName") , p));
queryResult.setParameter("schoolName", schoolName + "%");

但是,当学生被表示为java.util.List而不是基本属性时,我如何查询具有特定属性值的学生?

有人能帮我解决这个问题吗?我希望我已经能够解释我的问题。

谢谢

EN

回答 2

Stack Overflow用户

发布于 2012-02-29 13:00:32

代码语言:javascript
复制
CriteriaBuilder criteriaBuilder = getEntityManager().getCriteriaBuilder();
CriteriaQuery<School> query = criteriaBuilder.createQuery(School.class);
Root<School> schoolRoot = query.from(School.class);
Join<School, Student> join = schoolRoot.join(School_.students);
query.where(criteriaBuilder.equal(join.get(Student_.name), "john"));

它在所有的学校里查找一个叫约翰的学生。

票数 7
EN

Stack Overflow用户

发布于 2016-06-07 18:41:07

我猜那也会做类似的事情;

代码语言:javascript
复制
FROM School sch WHERE 'Student Name' = ANY (SELECT stud.name FROM sch.students stud)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9445426

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档