[英]Grails createCriteria on abstract domain
我很好奇如何使用条件构建器访问继承的类的字段。
假设我们有以下课程:
class A {
String fieldOne
String fieldTwo
static hasMany = [childs: AbstractChildClass]
}
并且抽象的子类如下所示:
abstract class AbstractChildClass {
Integer valueOne
Integer valueTwo
A a
static mapping
tablePerHierarchy false
}
}
当然,有几个扩展类,例如:
class ExtendingClassOne extends AbstractChildClass {
DesiredObject desiredObject
static mapping = {
tablePerHierarchy false
}
}
我们还假设存在DesiredObject类,如下所示:
class DesiredObject {
String infoA
String infoB
}
问题是如何通过为类A创建条件来获取字段infoA和infoB。到目前为止,我的方法是:
A.createCriteria().list {
childs {
desiredObject {
ilike('infoA', '%something%')
}
}
}
这当然是行不通的,因为在表ExtendingClassOne中只是所需对象的ID,我不知道如何将对象与条件构建器结合起来以获取其字段。
感谢您的阅读。
马尔科
不要期望您的域模型与其相关的数据库架构之间100%匹配。
在您的情况下,多态性仅tablePerHierarchy true
于AbstractChildClass的tablePerHierarchy true
。
如果您想坚持使用tablePerHierarchy false
,则可以像下面这样定义您的类:
class A {
static hasMany = [ childrenOne:ExtendingClassOne, childrenTwo:ExtendingClassTwo ]
}
因此,您的查询将非常简单:
A.withCriteria{
for( String c in [ 'childrenOne', 'childrenTwo' ] ){
"$c"{
desiredObject {
ilike('infoA', '%something%')
}
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.