Ограничения nhibernate.Eq и ноль - PullRequest
9 голосов
/ 01 августа 2010
Advertisements advertisements = NHibernateSession.CreateCriteria(typeof(Advertisements))
                    .Add(Restrictions.Eq(AdvertisementsProperties.Price.ToString(), price))
                    .Add(Restrictions.Eq(AdvertisementsProperties.HollidayDuration.ToString(), hollidayDuration))
                    .Add(Restrictions.Eq(AdvertisementsProperties.Name.ToString(), name))
                    .Add(Restrictions.Eq(AdvertisementsProperties.Description.ToString(), description))
                    //.Add(Restrictions.Eq(AdvertisementsProperties.DepartureDate.ToString(), departureDate))
                    .Add(Restrictions.Eq(AdvertisementsProperties.City.ToString(), city))
                    .Add(Restrictions.Eq(AdvertisementsProperties.Area.ToString(), area))
                    .Add(Restrictions.Eq(AdvertisementsProperties.Country.ToString(), country))
                    .Add(Restrictions.Eq(AdvertisementsProperties.Agency.ToString(), agency))
                    .UniqueResult<Advertisements>();

но город, район или страна могут быть нулевыми.Как сравнить ноль в БД с nhibernate?

Ответы [ 2 ]

15 голосов
/ 01 августа 2010
public AbstractCriterion EqOrNull(string property, object value) {
    if (value == null)
        return Restrictions.IsNull(property);
    return Restrictions.Eq(property, value);
}

например:.

session.CreateCriteria<Advertisements>()
       .Add(EqOrNull(AdvertisementsProperties.City.ToString(), city));

Также см. ЧЧЧ-2951

6 голосов
/ 01 августа 2010
session.CreateCriteria<Advertisements>()
       .Add(Expression.Or(
                 Expression.Eq("AdvName", "Cool Advertisement"),
                 Expression.IsNull("AdvName"))
        ).List<Advertisements>();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...