JPA Criterios de selección de todas las instancias con valores máximos en sus grupos

Hay una manera de escribir con JPA 2 CriteriaBuilder el equivalente de la siguiente consulta?

select * from season s1
where end = (
    select max(end)
    from season s2
    where s1.contest_id=s2.contest_id
);

En JPQL esta consulta es:

Select s1 from Season s1 
where s1.end = (
    select max(s2.end)
    from Season s2
    where s1.contest=s2.contest
)

OriginalEl autor Ivan Sopov | 2013-01-18

1 Kommentar

  1. 12

    Esto debería funcionar, con contest ser un básico Entero de la propiedad, o un ManyToOne propiedad apuntando a otro no básica de la Entidad.

    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();

    OriginalEl autor perissf

Kommentieren Sie den Artikel

Bitte geben Sie Ihren Kommentar ein!
Bitte geben Sie hier Ihren Namen ein

Pruebas en línea