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