Iva*_*pov 5 jpa criteria-api correlated-subquery jpa-2.0
有没有办法用JPA 2编写CriteriaBuilder相当于以下查询?
select * from season s1
where end = (
select max(end)
from season s2
where s1.contest_id=s2.contest_id
);
Run Code Online (Sandbox Code Playgroud)
在JPQL中,此查询是:
Select s1 from Season s1
where s1.end = (
select max(s2.end)
from Season s2
where s1.contest=s2.contest
)
Run Code Online (Sandbox Code Playgroud)
per*_*ssf 13
这应该有效,contest可以是基本的Integer属性,也可以是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();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
12051 次 |
| 最近记录: |