如何在grails域类中设置公式?

如何在grails域类中设置公式?,grails,gorm,grails-2.0,grails-domain-class,grails-services,Grails,Gorm,Grails 2.0,Grails Domain Class,Grails Services,我试图在我的域类中编写公式,帮助我创建条件 class MyClass { //some fields Date appointmentTime String ddmmyy int year int month int day static transients = [ 'ddmmyy', 'year', 'month', 'day' ] static mapp

我试图在我的域类中编写公式,帮助我创建条件

class MyClass {
    //some fields
    Date appointmentTime
    String ddmmyy
    int year
    int month
    int day
    static transients = [
        'ddmmyy',
        'year',
        'month',
        'day'
    ]
    static mapping= {
        ddmmyy formula('DATE_FORMAT(appointmentTime)')
        year formula('YEAR(appointmentTime)')
        month formula('MONTH(appointmentTime)')
        day formula('DAYOFMONTH(appointmentTime)')
    }
}
每当我试图在我的条件中使用此字段时,它就会抛出错误,即无法解析“myClass”的属性“ddmmyy”

我的标准是:

Date myDate = Calender.instance.time

def results = MyClass.createcriteria().list{
    lt('appointmentTime', date+1)
    ge('appointmentTime', date)
    projections {
        groupProperty('ddmmyy')
        count('id')
    }
}

知道我为什么会得到一个例外吗?

您需要将这些字段设置为非临时字段,以便在条件中使用。见参考文件


您的意思是此字段将与DB一起持久化吗?派生属性不会持久化,至少不会直接持久化。请参阅。如果它是派生属性,则不会是,但它必须是非瞬态的,才能由条件或动态查找程序使用。@HussainFakhruddin您可以更新链接;)请注意,ORM DSL中表示的公式是SQL,因此对其他属性的引用应该与持久性模型而不是对象模型相关,这就是为什么这个示例是错误的,因为它引用的是appointmentTime而不是APPOINTMENT\u TIME