NHibernate получить следующие дни рождения - PullRequest
2 голосов
/ 29 июня 2011

У меня есть таблица, которая содержит столбец День рождения типа DateTime. Теперь я должен выбрать с HQL всех людей, у которых День рождения будет в ближайшие 10 дней или был в последние 5 дней. Как я могу сделать это с NHibernate 3.2 HQL? Благодарю. Томас

Ответы [ 2 ]

2 голосов
/ 29 июня 2011

Я решил это с

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>();
0 голосов
/ 29 июня 2011

В 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))
...