>백엔드 개발 >C++ >필터 사전을 사용하여 LINQ에서 동적 WHERE 절을 작성하는 방법은 무엇입니까?

필터 사전을 사용하여 LINQ에서 동적 WHERE 절을 작성하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-14 08:32:46245검색

How to Build a Dynamic WHERE Clause in LINQ Using a Dictionary of Filters?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.