2

タイプ DateTime の列 Birthday を含むテーブルがあります。ここで、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 の 1 つの方法は次のとおりです。

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 に答える