我創建了一種自定義擴展方法來表示 SQL 'IN' 操作,我只是想讓它可重用且更直接。
public static bool In<T>(this T source, params T[] list)
{
return list.Contains(source);
}
問題是我無法讓它作業,我是這樣稱呼它的:
dataSource.Where(s => s.Id.In(6, 8)).Select(...);
這種方法雖然有效:
dataSource.Where(d => new int[] { 6, 8 }.Contains(d.Id)).Select(...)
我一直收到“無法翻譯 LINQ .Where(b => b.Id\r\n .In(__n_0))' 運算式......”
uj5u.com熱心網友回復:
我曾經寫過這個方法,利用運算式樹,基本上,你會這樣做:
dataSource.In(s => s.Id, 6, 8).Select(...);
代碼:
public static IQueryable<TSource> In<TSource, TMember>(this IQueryable<TSource> source,
Expression<Func<TSource, TMember>> identifier, params TMember[] values)
{
var parameter = Expression.Parameter(typeof(TSource), "m");
var inExpression = GetExpression(parameter, identifier, values);
var theExpression = Expression.Lambda<Func<TSource, bool>>(inExpression, parameter);
return source.Where(theExpression);
}
internal static Expression GetExpression<TSource, TMember>(ParameterExpression parameter, Expression<Func<TSource, TMember>> identifier, IEnumerable<TMember> values)
{
var memberName = (identifier.Body as MemberExpression).Member.Name;
var member = Expression.Property(parameter, memberName);
var valuesConstant = Expression.Constant(values.ToList());
MethodInfo method = typeof(List<TMember>).GetMethod("Contains");
Expression call = Expression.Call(valuesConstant, method, member);
return call;
}
可在GitHub和NuGet 上使用其他 LINQ 擴展:
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/391165.html
