比如说,我有两个域类:
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.name
对Foo
实例进行排序