में पहले aliased क्षेत्र का जिक्र करते हुए इस क्वेरी में:एक मापदंड क्वेरी
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Tuple> q = cb.createTupleQuery();
// FROM GamePlayedEvent gpe
Root<GamePlayedEvent> gpe = q.from(GamePlayedEvent.class);
// SELECT gameId, COUNT(*) AS count, AVG(duration)
// AS avDur, AVG(rewardCurrency) AS avCur, AVG(rewardXP) avXp
q.select(cb.tuple(
gpe.<String>get("gameId"),
cb.count(gpe).alias("count"),
cb.avg(gpe.<Double>get("duration")).alias("avDur"),
cb.avg(gpe.<Integer>get("rewardCurrency")).alias("avCur"),
cb.avg(gpe.<Integer>get("rewardXp")).alias("avXp")
));
// WHERE loginTime BETWEEN ...
q.where(cb.between(gpe.<Date>get("time"), fromTime, toTime));
// GROUP BY gameId
q.groupBy(gpe.<String>get("gameId"));
// ORDER BY count DESC
q.orderBy(cb.desc(???));
मैं ORDER BY count DESC
कैसे जोड़ सकते हैं, "गिनती" SELECT
खंड में परिभाषित की चर्चा करते हुए?
यह हाइबरनेट मानदंड API है। यह प्रश्न जेपीए 2 मानदंड एपीआई (और यह हाइबरनेट कार्यान्वयन) के बारे में है। उलझन में पर्याप्त, वे एक ही बात नहीं हैं। –