>  기사  >  백엔드 개발  >  Linq의 ID 목록이 있는 엔터티를 \'Contains()\'가 없는 엔터티로 필터링하는 방법은 무엇입니까?

Linq의 ID 목록이 있는 엔터티를 \'Contains()\'가 없는 엔터티로 필터링하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-02 04:00:30841검색

How to Filter Entities with a List of IDs in Linq to Entities without 'Contains()'?

Linq to Entities: 확장 메서드를 사용하는 'Contains()'에 대한 대안

'Contains()' 메서드는 다음에서 직접 지원되지 않습니다. Linq to Entities는 ID 목록을 기반으로 엔터티를 필터링할 때 문제를 제기합니다. 이 제한 사항을 해결하기 위해 확장 메서드를 사용하는 대체 접근 방식을 사용할 수 있습니다.

해결책:

'WhereIn()' 확장 메서드는 'Contains'에 대한 해결 방법을 제공합니다. ()' 비교를 일련의 'Equals()' 표현식으로 변환합니다. 이 확장 메서드는 다음과 같이 구현할 수 있습니다.

<code class="csharp">public static IQueryable<TEntity> WhereIn<TEntity, TValue>
(
    this ObjectQuery<TEntity> query,
    Expression<Func<TEntity, TValue>> selector,
    IEnumerable<TValue> collection
)
{
    // ... implementation details omitted ...
}</code>

사용법:

'WhereIn()' 메서드는 다음 항목의 컬렉션을 기반으로 엔터티를 필터링하는 데 사용할 수 있습니다. ID:

<code class="csharp">List<long?> txnIds = new List<long?>();
// Fill txnIds

var q = from t in svc.OpenTransaction
        where txnIds.WhereIn(t => t.OpenTransactionId)
        select t;</code>

또는 ID 컬렉션이 정적인 경우 확장 메서드에 직접 제공할 수 있습니다.

<code class="csharp">var q = context.Contacts.WhereIn(c => c.Name,
      "Contact1",
      "Contact2",
      "Contact3",
      "Contact4"
      );</code>

참고:

Entity Framework 버전 4 이상에서는 'Contains()' 메서드가 직접 지원되므로 여기에 제시된 해결 방법이 필요하지 않습니다.

위 내용은 Linq의 ID 목록이 있는 엔터티를 \'Contains()\'가 없는 엔터티로 필터링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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