嵌套属性上的不区分大小写的顺序



比如说,我有两个域类:

class Foo {
   Bar bar
   Long baz
}
class Bar {
   String name
}

我有一个电话打进了一个createCriteria,它想要按酒吧的名称(或客户想要排序的任何其他有效属性)进行排序,忽略了大小写。 我已经能够将其减少到:

Foo.createCriteria().list() {
    //...
    bar {
        order((params.sortOrder == 'asc' ? 
            Order.asc('name') : // 'name' is a variable in the real code 
            Order.desc('name')
        ).ignoreCase())
    }
}

但是当排序属性嵌套时(即 bar 的属性),我得到一个异常:

org.hibernate.QueryException: could not resolve property: name of: Foo

我发现了这些相关的Grails错误GRAILS-8182,GRAILS-9171,GRAILS-3911,这使得它看起来像是存在许多错误的组合,使我想做的事情变得不可能。

有没有办法对createCriteria中的嵌套属性进行不区分大小写的排序? 我意识到我可以在客户端或Groovy列表上进行排序,但我真的不希望重新发明轮子(特别是因为它将是一个非常丑陋的轮子)。

我正在使用Grails 2.2.4。

我在尝试解决与 grails 排序相关的类似问题时偶然发现了这个问题。也许与此同时已经找到了解决方案。如果没有,我想建议你尝试以下方法:

Foo.createCriteria().list() {
    createAlias("bar","_b")
    order("_b.name", (params.sortOrder == "asc")?"asc":"desc")
}

通过这种方式,您应该能够按bar.nameFoo实例进行排序

相关内容

  • 没有找到相关文章

最新更新