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

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

Nov 02, 2024 am 04:00 AM

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&lt;TEntity&gt; WhereIn&lt;TEntity, TValue&gt;
(
    this ObjectQuery&lt;TEntity&gt; query,
    Expression&lt;Func&lt;TEntity, TValue&gt;&gt; selector,
    IEnumerable&lt;TValue&gt; collection
)
{
    // ... implementation details omitted ...
}</code>
로그인 후 복사

사용법:

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

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

var q = from t in svc.OpenTransaction
        where txnIds.WhereIn(t =&gt; t.OpenTransactionId)
        select t;</code>
로그인 후 복사

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

<code class="csharp">var q = context.Contacts.WhereIn(c =&gt; c.Name,
      "Contact1",
      "Contact2",
      "Contact3",
      "Contact4"
      );</code>
로그인 후 복사

참고:

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

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

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C 언어 함수 형식 문자 케이스 변환 단계 C 언어 함수 형식 문자 케이스 변환 단계 Mar 03, 2025 pm 05:53 PM

C 언어 함수 형식 문자 케이스 변환 단계

C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까? C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까? Mar 03, 2025 pm 05:52 PM

C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까?

Gulc : C 도서관은 처음부터 구축되었습니다 Gulc : C 도서관은 처음부터 구축되었습니다 Mar 03, 2025 pm 05:46 PM

Gulc : C 도서관은 처음부터 구축되었습니다

C 언어 기능의 정의 및 호출 규칙은 무엇이며 C 언어 기능의 정의 및 호출 규칙은 무엇이며 Mar 03, 2025 pm 05:53 PM

C 언어 기능의 정의 및 호출 규칙은 무엇이며

C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까? C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까? Mar 12, 2025 pm 04:50 PM

C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까?

메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까? 메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까? Mar 03, 2025 pm 05:51 PM

메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까?

뚜렷한 사용 및 문구 공유 뚜렷한 사용 및 문구 공유 Mar 03, 2025 pm 05:51 PM

뚜렷한 사용 및 문구 공유

STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까? STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까? Mar 12, 2025 pm 04:52 PM

STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까?

See all articles