Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/video/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
NHibernate HQL日期函数_Nhibernate_Hql - Fatal编程技术网

NHibernate HQL日期函数

NHibernate HQL日期函数,nhibernate,hql,Nhibernate,Hql,我正在使用C和NHibernate编写一个通知平台。我很难回答我的问题 我有一个客户实体-其中包含一个评估已完成的财产。应在认证后21个月发出通知。因此,我的查询需要包括其评估完成日期+21个月

我正在使用C和NHibernate编写一个通知平台。我很难回答我的问题

我有一个客户实体-其中包含一个评估已完成的财产。应在认证后21个月发出通知。因此,我的查询需要包括其评估完成日期+21个月<当前日期的所有客户。我如何做到这一点?NHibernate中是否有一个月添加方法?我需要在每个评估完成的财产上加上21个月。我的查询需要如下所示:

SELECT new Notification(c.Id, c.Description, c.AssessmentCompleted + 21
            FROM Cusomter c 
            AND c.AssessmentCompleted + 21 <= :EndDate

您可以从使用的方言继承并注册函数

例如,对于MS SQL,可以按如下方式注册dateadd函数:

公共类MyExtendedDMSql2012Dialect:MsSql2012Dialect { 受保护的覆盖无效注册表函数 { base.RegisterFunctions; RegisterFunctiondateadd,新的SQLFunctionTemplateNHibernateUtil.Date,dateadd?1、?2、?3; } }
然后,如果您配置了该方言,您将能够在HQL和Criteria API中使用它。

为什么您不能只删除参数EndDate的21个月?同意jishi-这只剩下一个减法,而不是成百上千