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

findAll()HQL不返回grails中的分页列表,grails,pagination,Grails,Pagination,我正在开发一个grails应用程序,在这个应用程序中,我必须在list.gsp上应用过滤器框。当我使用以下查询(在我的服务中)进行筛选时,我得到的是分页列表: def clientCriteria = TripOrder.createCriteria() def searchResults = clientCriteria.list(max: params.max, offset: params.offset, sort: params.sort, order: para

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

    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时,我无法获得分页列表,查询如下:

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代替条件查询

以上结果仅提供等于max的列表数量,而不是提供分页列表

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


谢谢。

findAll
不是用来返回分页列表的。它返回一个数组。这一点在中有明确说明。

根据您的评论,您可以在获得
PagedResultList

def results = TripOrder.createCriteria.list(params) {
    customer {
       ilike 'firstName', "%$searchFor%" 
    }
}

assert results.size() != results.totalCount
它基本上会触发另一个totalCount查询,如果您想坚持使用
findAll
或类似findAll的内容而不是条件,那么您可以通过使用
DetachedCriteria
/
where query
来吸收更好的替代方法,它会根据需要延迟执行查询。同样,您将无法在第一次查询中获得总计数。你必须为同样的原因再解雇一个

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()

findAll不返回分页列表,它根据文档返回一个数组:……因此,他们在grails中获取分页列表的唯一方法是仅使用条件查询。您能告诉我如何比较作为域类实例的Doamin属性,例如:class TripOrder吗{Person customer String status}类Person{String firstName String middleName}我想使用条件查询比较TripOrder的customer.firstName属性,我将如何实现这一点。谢谢。根据我的问题,您给出的答案似乎是正确的。但我正在寻找由dmahapatro提供的解决方案。因此,我将他的答案标记为正确答案,并对您的答案进行投票。谢谢非常感谢你的精彩解释,我一直在寻找你提供的解决方案,这对我帮助很大。