У меня есть следующий запрос lamba, который всегда возвращает все записи, даже если int? status pamameter не является нулевым и действительным. Кто-нибудь знает, почему фильтр Enum не соблюдается? Спасибо за чтение!Lambda Query filter by Enum
public ActionResult GetArrivals(int facilityId, int? status)
{
var registrationList = db.Registrations
.Where(f => f.Facility.Id == facilityId)
.Where(a => a.ArrivalDateTime >= DateTime.Today)
.OrderBy(ln => ln.User.LastName)
.OrderBy(fn => fn.User.FirstName);
if (status.HasValue)
{
UrgentCareWaitWeb.Models.RegistrationStatus statusValue;
if (Enum.TryParse(status.Value.ToString(), out statusValue) == true)
{
registrationList
.Where(s => s.Status == statusValue);
}
}
// Project query to view
var pview = registrationList.Select(r => new PatientRegistrationsView()
{
ArrivalId = r.Id,
UserId = r.User.UserId,
UserName = r.User.UserName,
FirstName = r.User.FirstName,
LastName = r.User.LastName,
PrimaryPhone = r.User.PrimaryPhone,
SecondaryPhone = r.User.SecondaryPhone,
ArrivalDateTime = r.ArrivalDateTime,
PatientDataformId = r.PatientDataformId,
RegistrationStatus = r.Status,
});
//if (Request.IsAjaxRequest())
// return PartialView("_PatientRegistrations", model);
return View(pview);
}
Очень ценный ответ. Я заменил этот код тем, который вы опубликовали, но он не компилируется. Невозможно неявно преобразовать тип 'System.Linq.IQueryable' в 'System.Linq.IOrderedQueryable '. Явное преобразование существует (вы пропускаете листинг?) –
ChiliYago
Ah - обновленный ответ. – eouw0o83hf
Это, вероятно, работает, но я нашел из другого сообщения, что замена объявления «var» на явный идентификатор регистрации IQueryable И применяя ваш код, он работает нормально. Спасибо огромное! –
ChiliYago