하나의 데이터베이스 필드에서 여러 키워드를 검색해야 합니다. 이는 다음과 같은 SQL 쿼리를 사용하여 달성할 수 있습니다.
<code class="language-sql">select * from MainList where Comment like '%keyword1%' or Comment like '%keyword2%' ... 以此类推,直到最后一个关键词。</code>
C#에서는 다음과 같이 할 수 있습니다.
<code class="language-csharp">var newList = MainList .FilterByItems(keywords, (m, k) => m.Comments.Contains(k), true) .ToList();</code>
다음은 FilterByItems
확장 메소드의 구현입니다.
<code class="language-csharp">public static class QueryableExtensions { public static IQueryable<T> FilterByItems<T, TItem>(this IQueryable<T> query, IEnumerable<TItem> items, Expression<Func<T, TItem, bool>> filterPattern, bool isOr) { Expression? predicate = null; foreach (var item in items) { var itemExpr = Expression.Constant(item); var itemCondition = ExpressionReplacer.Replace(filterPattern.Body, filterPattern.Parameters[1], itemExpr); if (predicate == null) predicate = itemCondition; else { predicate = Expression.MakeBinary(isOr ? ExpressionType.OrElse : ExpressionType.AndAlso, predicate, itemCondition); } } predicate ??= Expression.Constant(false); var filterLambda = Expression.Lambda<Func<T, bool>>(predicate, filterPattern.Parameters[0]); return query.Where(filterLambda); } class ExpressionReplacer : ExpressionVisitor { readonly IDictionary<Expression, Expression> _replaceMap; public ExpressionReplacer(IDictionary<Expression, Expression> replaceMap) { _replaceMap = replaceMap ?? throw new ArgumentNullException(nameof(replaceMap)); } [return: NotNullIfNotNull(nameof(node))] public override Expression? Visit(Expression? node) { if (node != null && _replaceMap.TryGetValue(node, out var replacement)) return replacement; return base.Visit(node); } public static Expression Replace(Expression expr, Expression toReplace, Expression toExpr) { return new ExpressionReplacer(new Dictionary<Expression, Expression> { { toReplace, toExpr } }).Visit(expr); } public static Expression Replace(Expression expr, IDictionary<Expression, Expression> replaceMap) { return new ExpressionReplacer(replaceMap).Visit(expr); } public static Expression GetBody(LambdaExpression lambda, params Expression[] toReplace) { if (lambda.Parameters.Count != toReplace.Length) throw new InvalidOperationException(); return new ExpressionReplacer(Enumerable.Range(0, lambda.Parameters.Count) .ToDictionary(i => (Expression)lambda.Parameters[i], i => toReplace[i])).Visit(lambda.Body); } } }</code>
위 내용은 C#에서 람다 표현식과 함께 여러 키워드를 사용하여 목록을 효율적으로 필터링하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!