首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Hibernate选择SubQuery

Hibernate选择SubQuery
EN

Stack Overflow用户
提问于 2015-09-04 13:54:53
回答 2查看 509关注 0票数 1

我有以下的hql查询:

代码语言:javascript
复制
JgrelhasListBack = session.createQuery("from Jgrelhas where jtabuleiros.id=? and id<? order by id desc").setParameter(0, tabuleiroId).setParameter(1, grelhaId).setMaxResults(limitenovo).list();

我需要得到最后5个结果,所以我所做的是命令它,得到最大的结果5。但我需要它由Asc.

我找到了一个解决方案,就是这样进行查询:

代码语言:javascript
复制
SELECT * FROM (
    SELECT * FROM table ORDER BY id DESC LIMIT 50
) sub
ORDER BY id ASC

我试图在hql中复制它,但没有成功:

代码语言:javascript
复制
JgrelhasListBack = session.createQuery("select (select Jgrelhas from Jgrelhas where jtabuleiros.id=? and id<? order by id desc ) from Jgrelhas order by id asc").setParameter(0, tabuleiroId).setParameter(1, grelhaId).setMaxResults(limitenovo).list();

提前感谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-09-04 15:51:19

最简单的方法是反转desc顺序列表:

代码语言:javascript
复制
List jgrelhasListBack = session.createQuery("from Jgrelhas where jtabuleiros.id=? and id<? order by id desc")
    .setParameter(0, tabuleiroId)
    .setParameter(1, grelhaId)
    .setMaxResults(limitenovo)
    .list();
return java.util.Collections.reverse(jgrelhasListBack);
票数 1
EN

Stack Overflow用户

发布于 2015-09-04 14:44:39

您不能在HQL中使用from子句执行子查询。只支持select/where子句。

要么尝试通过本机SQL查询

(或)转换为where子句如下所示。

代码语言:javascript
复制
select Jgrelhas from Jgrelhas
where id IN   
(select id from Jgrelhas
where jtabuleiros.id=? and id<? order by id desc )
order by id asc
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32399888

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档