OR 조건을 사용하여 엔터티 쿼리에 대한 동적 LINQ 구축
동적 LINQ 쿼리를 만들려면 여러 WHERE 절을 결합해야 하는 경우가 많습니다. 표준 LINQ는 AND 조건을 쉽게 처리하지만 동적 OR 조건을 구성하는 것은 어렵습니다. 이 기사에서는 이를 달성하기 위해 LINQKit의 PredicateBuilder
을 사용하는 솔루션을 보여줍니다.
핵심은 유연한 조건자 생성을 위해 PredicateBuilder
를 활용하고 Entity Framework와의 호환성을 보장하는 것입니다. 다음 코드는 이러한 접근 방식을 예시합니다.
<code class="language-csharp">var query = from u in context.Users select u; var pred = PredicateBuilder.False<User>(); // Start with a predicate that's always false if (type.HasFlag(IdentifierType.Username)) pred = pred.Or(u => u.Username == identifier); if (type.HasFlag(IdentifierType.Windows)) pred = pred.Or(u => u.WindowsUsername == identifier); // Corrected parenthesis return query.Where(pred.Expand()).FirstOrDefault(); // or return query.AsExpandable().Where(pred).FirstOrDefault();</code>
결정적으로 pred.Expand()
또는 query.AsExpandable()
의 사용에 유의하세요. PredicateBuilder
은 Entity Framework가 직접 지원하지 않는 식을 생성하기 때문에 이는 필수적입니다. Expand()
(또는 AsExpandable()
)은 LINQKit의 표현식 방문자를 활용하여 이러한 표현식을 Entity Framework와 호환되는 형식으로 변환하여 예외를 방지합니다.
대안으로 Peter Montgomery(PredicateBuilder
https://www.php.cn/link/451e10de8e2fb18a9f795679b52dc9f6)의 구현과 같은 다른 구현을 살펴보는 것도 고려해 보세요. 명시적인 Expand()
호출이 필요합니다. 이는 LINQ to Entities 쿼리 내에서 동적 OR 조건을 구성하는 간소화된 접근 방식을 제공합니다.
위 내용은 동적 LINQ에서 엔터티 쿼리에 WHERE 절을 연결하기 위해 OR 논리를 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!