Мне нужно было создать динамический фильтр, и я хотел продолжать использовать сущности. По этой причине я хотел использовать PredicateBuilder от albahari.
Я создал следующий код:
var invoerDatums = PredicateBuilder.True<OnderzoeksVragen>();
var inner = PredicateBuilder.False<OnderzoeksVragen>();
foreach (var filter in set.RapportInvoerFilter.ToList())
{
if(filter.IsDate)
{
var date = DateTime.Parse(filter.Waarde);
invoerDatums = invoerDatums.Or(o => o.Van >= date && o.Tot <= date);
}
else
{
string temp = filter.Waarde;
inner = inner.Or(o => o.OnderzoekType == temp);
}
}
invoerDatums = invoerDatums.And(inner);
var onderzoeksVragen = entities.OnderzoeksVragen
.AsExpandable()
.Where(invoerDatums)
.ToList();
Когда я запустил код, был только 1 фильтр, который не был фильтром даты. Таким образом, был заполнен только внутренний предикат. Когда предикат был выполнен, я получил следующую ошибку.
Параметр "f" не был связан в указанном выражении запроса LINQ to Entities.
При поиске ответа я обнаружил следующее: страница. Но это уже реализовано в LINQKit.
Кто-нибудь еще сталкивался с этой ошибкой и знает, как ее решить?