LINQ에서 동적 WHERE 절 작성
LINQ는 데이터 탐색을 위한 선언적 구문을 사용하여 데이터베이스 쿼리에 유연성을 제공합니다. 일반적인 상황은 일반적으로 다양한 소스의 사용자 입력 또는 필터 조건을 처리할 때 동적 WHERE 절이 필요한 경우입니다. 이를 달성하기 위한 일반적인 접근 방식은 조건절을 사용하여 WHERE 절을 확장하는 것입니다.
특정 시나리오에서는 사전을 사용하여 여러 필터를 전달합니다. 다음 코드 조각을 고려해보세요.
<code class="language-csharp">public IOrderedQueryable<productdetail> GetProductList(string productGroupName, string productTypeName, Dictionary<string, List<string>> filterDictionary) { var q = from c in db.ProductDetail where c.ProductGroupName == productGroupName && c.ProductTypeName == productTypeName // 在此处插入动态过滤器 orderby c.ProductTypeName select c; return q; }</code>
동적 WHERE 절을 조합하려면 다음 접근 방식을 사용할 수 있습니다.
<code class="language-csharp">if (filterDictionary != null) { foreach (var filter in filterDictionary) { string fieldName = filter.Key; foreach (string value in filter.Value) { var innerWhereClause = Expression.Lambda<Func<ProductDetail, bool>>( Expression.Equal(Expression.Property(Expression.Parameter(typeof(ProductDetail), "c"), fieldName), Expression.Constant(value)), Expression.Parameter(typeof(ProductDetail), "c")); q = q.Where(innerWhereClause); } } }</code>
이 코드에서 동적 WHERE 절은 사전을 반복하고 각 필터에 대한 람다 식을 구성하여 동적으로 생성됩니다. 그런 다음 동적으로 생성된 이 표현식을 기존 WHERE 절에 추가합니다. 조건절과 표현식 트리를 사용하면 유연하고 확장 가능한 WHERE 절을 작성하여 특정 필터링 요구 사항을 충족할 수 있습니다.
이 수정된 답변은 문장을 바꾸고 약간 다른 표현을 사용하면서 원래 의미를 유지합니다. 명확성과 정확성을 위해 코드 예제가 약간 개선되었습니다(특히 Expression.Parameter
사용법).
위 내용은 필터 사전을 사용하여 LINQ에서 동적 WHERE 절을 작성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!