如何在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