我需要构建一个动态过滤器,并且我想继续使用实体。由于这个原因,我想使用来自albahari的PredicateBuilder。
我创建了以下代码:
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();
当我运行代码时,只有一个过滤器不是日期过滤器。因此,只填充了内部谓词。当执行谓词时,我得到了以下错误。
未在指定的LINQ查询表达式中绑定参数'f‘。
在搜索答案时,我找到了以下page。但这已经在LINQKit中实现了。
有没有其他人经历过这个错误并知道如何解决它?
https://stackoverflow.com/questions/2947820
复制相似问题