首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >findAll() HQL不返回grails中的分页列表

findAll() HQL不返回grails中的分页列表
EN

Stack Overflow用户
提问于 2014-03-26 17:25:00
回答 2查看 1.8K关注 0票数 3

我正在处理一个grails应用程序,在这个过程中,我必须在list.gsp上应用过滤器框。当我使用以下查询(在我的服务中)进行过滤时,我得到了分页列表

代码语言:javascript
运行
复制
    def clientCriteria = TripOrder.createCriteria()
        def searchResults = clientCriteria.list(max: params.max, offset: params.offset, sort: params.sort, order: params.order){
            ilike("origin", "${searchFor}%")
        }
        println searchResults.getTotalCount()
        [searchResults: searchResults, searchResultSize: searchResults.getTotalCount()]

但我的问题是,当我使用findAll时,我无法获得分页列表,查询如下:

代码语言:javascript
运行
复制
def searchResults =  TripOrder.findAll("from TripOrder as t where t.status.status=:status", [status: searchFor], [max: maximum, sort: params.sort, order: params.order])

            println searchResults.size()

            [searchResults: searchResults, searchResultSize: searchResults.size()]

注意事项:由于某些原因,我不得不使用findAll() HQL代替标准查询。

以上结果只提供等于最大值的列表数,而不是提供分页列表

请提供使用findAll()获取分页列表的解决方案。

谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-03-26 17:59:26

根据您的评论,您可以在获得PagedResultList的情况下这样做

代码语言:javascript
运行
复制
def results = TripOrder.createCriteria.list(params) {
    customer {
       ilike 'firstName', "%$searchFor%" 
    }
}

assert results.size() != results.totalCount

它基本上会为totalCount触发另一个查询,如果您想坚持使用findAll或类似于findAll之类的东西,而不是使用标准,那么您可以通过使用DetachedCriteria/where query来吸收更好的选择,后者可以根据需要懒散地执行查询。同样,您将无法在第一次查询中获得总数。你还得为同样的事再炒一次。

代码语言:javascript
运行
复制
def query = TripOrder.where {
    customer.firstName =~ searchFor
}

//Query executed only when list() is called
def results = query.list( params )

//Only executed when count() is called
def totalCount = query.count()
票数 4
EN

Stack Overflow用户

发布于 2014-03-26 17:28:23

findAll不是为返回分页列表而设计的。它返回一个数组。这一点在文档中有明确的表述。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22668609

复制
相关文章

相似问题

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