2015-04-25 39 views
0

我在将HQL转换为标准查询时遇到了一些问题。作为规范的一部分,我需要Criteria查询的返回值是Criteria类型,这可能不会改变。HQL到标准转换问题

这是我的全部工作HQL查询:

select sum(m.frequent/case when m.vigilants.size > 1 then m.vigilants.size 
else 1 end) from Museum m inner join m.vigilants v where size(m.vigilants) > 1 
and v.forename = 'Mike Jones' or size(m.vigilants) = 1 and v.forename='Mike Jones' 

,这是我的尝试,到目前为止,在得到一个条件查询

Criteria criteria = session.createCriteria(Museum.class, "m"); 
criteria.createAlias("m.vigilants", "v"); 
criteria.setProjection(Projections.distinct(Projections.property("m.id"))); 
criteria.add(Restrictions.or(Restrictions.sizeGt("vigilants", 1), Restrictions.eq("v.forename", "Mike Jones"))); 

老实说,我真的很卡住,一直试图一天让这个工作,并且我不知道如何让这个HQL转换为Criteria查询!

回答

0

在我得到完全正确的信息之前,我通常不得不摆弄这些东西一段时间,但是这里是第一次开始。

另外,整个size > 1 or size == 1事情归结为size >= 1这是隐含的,如果你正在做一个内部连接,所以我只是把它遗漏了。

CriteriaBuilder builder = entityManager.getCriteriaBuilder(); 
CriteriaQuery<Number> query = builder.createQuery(Long.class); 
Root<Museum> root = query.from(Museum.class); 
Join<Museum, Vigilant> vigilantsJoin = root.join("vigilants"); 
Predicate forenameIsMikeJones = builder.equal(vigilantsJoin.get("forename"), "Mike Joines"); 
Expression<Integer> numVigilants= builder.size(root.get("vigilants")); 
Expression<Number> freqOverNumVigilants = builder.quot(root.get("frequent"), numVigilants); 
Expression<Sum> sumOfFreqOverNumVigilants = builder.sum(freqOverNumVigilants); 
query.select(sumOfFreqOverNumVigilants).where(forenameIsMikeJones); 
TypedQuery<Number> typedQuery = entityManager.createQuery(query);