一部のデータを動的にフィルタリングできるように、式ツリーを作成するのに苦労しています。
私はこれを思いついたが、それはvar lambda =
ラインで失敗する
foreach (var rule in request.Where.Rules)
{
var parameterExpression = Expression.Parameter(typeof(string), rule.Field);
var left = Expression.Call(parameterExpression, typeof(string).GetMethod("ToLower", Type.EmptyTypes));
var right = Expression.Constant(rule.Data.ToLower());
var method = typeof(string).GetMethod("Contains", new [] { typeof(string) });
var call = Expression.Call(left, method, right);
var lambda = Expression.Lambda<Func<T, bool>>(call, parameterExpression);
query = query.Where(lambda);
}
varには、 (ex'tom')のrule
テキストと比較したいフィールド(ex "Name")があります。rule.Data
したがってT.Name.Contains("tom");
、クエリにレコードを含めたい場合は、そうでない場合は含めません。
varquery
はタイプですIQueryable<T>
編集:ついにこのコードで動作するようになりました:
foreach (var rule in request.Where.Rules)
{
var parameter = Expression.Parameter(typeof(T), "x");
var property = Expression.Property(parameter, rule.Field);
var value = Expression.Constant(rule.Data);
var type = value.Type;
var containsmethod = type.GetMethod("Contains", new[] { typeof(string) });
var call = Expression.Call(property, containsmethod, value);
var lambda = Expression.Lambda<Func<T, bool>>(call, parameter);
query = query.Where(lambda);
}