繁体   English   中英

在抽象域上使用Grails createCriteria

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM