JPA条件选择组中具有最大值的所有实例

JPA条件选择组中具有最大值的所有实例,jpa,jpa-2.0,criteria-api,correlated-subquery,Jpa,Jpa 2.0,Criteria Api,Correlated Subquery,有没有一种方法可以用JPA2CriteriaBuilder编写以下查询的等价物 从第1季中选择* 其中end= 选择maxend 从第二季开始 其中s1.contest\u id=s2.contest\u id ; 在JPQL中,此查询是: Select s1 from Season s1 where s1.end = ( select max(s2.end) from Season s2 where s1.contest=s2.contest ) 这应该是可行的,因

有没有一种方法可以用JPA2CriteriaBuilder编写以下查询的等价物

从第1季中选择* 其中end= 选择maxend 从第二季开始 其中s1.contest\u id=s2.contest\u id ; 在JPQL中,此查询是:

Select s1 from Season s1 
where s1.end = (
    select max(s2.end)
    from Season s2
    where s1.contest=s2.contest
)
这应该是可行的,因为contest是一个基本整数属性,或者是指向另一个非基本实体的ManyToOne属性

EntityManger em;      //to be injected or constructed

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Season> cq = cb.createQuery(Season.class);
Subquery<Date> sq = cq.subquery(Date.class);
Root<Season> s1 = cq.from(Season.class);
Root<Season> s2 = sq.from(Season.class);
sq.select(cb.greatest(s2.get(Season_.end)));
sq.where(cb.equal(s2.get(Season_.contest), s1.get(Season_.contest)));
cq.where(cb.equal(s1.get(Season_.end), sq));
List<Season> result = em.createQuery(cq).getResultList();