2

我有一个表,其中包含 DateTime 类型的生日列。现在我应该用 HQL 选择所有生日在接下来的 10 天或过去 5 天的人。如何使用 NHibernate 3.2 HQL 做到这一点?谢谢。托马斯

4

2 回答 2

2

我已经解决了

var result =
session.CreateQuery(@"from Person 
                      where 1 = (FLOOR(DATEDIFF(dd,Birthday,GETDATE()+10) / 365.25))
                                    -
                                (FLOOR(DATEDIFF(dd,Birthday,GETDATE()-5) / 365.25))")
       .List<Person>();
于 2011-06-29T10:06:21.157 回答
0

在 HQL 中,一种方法是:

Session.CreateQuery("FROM PersonTable WHERE Birthday <= :todayPlusTenDays AND Birthday >= :todayLessFiveDays")
.SetParameter(":todayPlusTenDays", DateTime.Today.AddDays(10))
.SetParameter(":todayLessFiveDays", DateTime.Today.AddDays(-5))

或者,但是我不确定两者之间是否包含在内或不在我的脑海中:

Session.CreateQuery("FROM PersonTable WHERE Birthday BETWEEN :todayLessFiveDays AND :todayPlusTenDays")
    .SetParameter(":todayPlusTenDays", DateTime.Today.AddDays(10))
    .SetParameter(":todayLessFiveDays", DateTime.Today.AddDays(-5))
于 2011-06-28T20:17:36.950 回答