Я просто отправлю код:
public IList<Dish> GetByNameDishTypes(IEnumerable<string> names,
IEnumerable<string> dishTypes)
{
// return dishes (ie food) whose name is in the names enumerable,
// or whose type is in the dish types enumerables
// (this would be 'breakfast', 'dinner') ..
var namesArr = names != null ? names.ToArray() : new string[0];
var dishTypesArr = dishTypes != null ? dishTypes.ToArray() : new string[0];
var criteria = this.Session.CreateCriteria<Dish>();
criteria.CreateAlias("DishType", "dt");
criteria.Add(
Restrictions.Or
(
Restrictions.In("Name", namesArr),
Restrictions.In("dt.Name", dishTypesArr)
));
return criteria.List<Dish>();
/* get this to work?
Dish d = null;
DishType dt = null;
return this.Session.QueryOver<Dish>(() => d)
.JoinAlias(() => d.DishType, () => dt)
.Where(
Restrictions.Or
(
Restrictions.In(d.Name, namesArr),
Restrictions.In(dt.Name, dishTypesArr)
))
.List<Dish>(); */
}
Итак, я хотел бы знать, как это сделать с QueryOver. Этот код QueryOver, который я опубликовал, генерирует исключение с нулевой ссылкой. Код критериев работает.
Спасибо:)