목차
LINQ Lambda 표현식을 사용하여 다중 테이블 조인 수행
소개
질문
답변
백엔드 개발 C++ LINQ 람다 표현식을 사용하여 여러 테이블을 효율적으로 조인하는 방법은 무엇입니까?

LINQ 람다 표현식을 사용하여 여러 테이블을 효율적으로 조인하는 방법은 무엇입니까?

Jan 10, 2025 am 11:36 AM

How to Efficiently Join Multiple Tables Using LINQ Lambda Expressions?

LINQ Lambda 표현식을 사용하여 다중 테이블 조인 수행

소개

LINQ에서는 여러 테이블을 조인하여 다양한 데이터 소스의 데이터를 결합할 수 있습니다. 이 문서에서는 LINQ에서 람다 식을 사용하여 다중 테이블 조인을 수행하는 방법을 설명합니다.

질문

Product, Category, ProductCategory라는 세 개의 테이블을 조인하려고 합니다. 연결 후 모든 관련 클래스 속성을 결합하는 단일 클래스를 얻으려고 합니다. 그러나 작성한 코드는 예상한 결과를 생성하지 않는 것 같습니다.

답변

LINQ 람다 식에서 여러 연결을 연결할 때 중간 결과는 익명 유형으로 표시됩니다. 즉, 각 조인의 결과는 조인된 테이블의 속성을 결합하는 새로운 익명 유형이 됩니다.

모든 관련 클래스 속성을 포함하는 단일 클래스를 얻으려면 최종 결과에 포함할 속성을 지정해야 합니다. 이는 Select 연산자를 사용하여 수행할 수 있습니다.

수정된 코드는 다음과 같습니다.

<code>var categorizedProducts = product
    .Join(productcategory, p =&gt; p.Id, pc =&gt; pc.ProdId, (p, pc) =&gt; new { p, pc })
    .Join(category, ppc =&gt; ppc.pc.CatId, c =&gt; c.Id, (ppc, c) =&gt; new { ppc, c })
    .Select(m =&gt; new { 
        ProdId = m.ppc.p.Id, // 或 m.ppc.pc.ProdId
        CatId = m.c.CatId
        // 其他赋值
    });</code>
로그인 후 복사

이 코드에서는 먼저 세 테이블 간의 조인을 수행하고 결과를 중간 익명 유형에 저장합니다. 그런 다음 Select 연산자를 사용하여 최종 결과를 필수 속성(ProdId 및 CatId)이 포함된 새로운 익명 형식으로 프로젝션합니다.

람다 표현식 대신 쿼리 구문을 사용하면 코드를 더욱 단순화할 수 있습니다.

<code>var categorizedProducts =
    from p in product
    join pc in productcategory on p.Id equals pc.ProdId
    join c in category on pc.CatId equals c.Id
    select new {
        ProdId = p.Id, // 或 pc.ProdId
        CatId = c.CatId
        // 其他赋值
    };</code>
로그인 후 복사

쿼리 구문은 특히 여러 조인이 포함된 복잡한 쿼리에서 읽기 쉽고 이해하기 쉽습니다.

위 내용은 LINQ 람다 표현식을 사용하여 여러 테이블을 효율적으로 조인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 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:52 PM

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

C 언어 함수 형식 문자 케이스 변환 단계 C 언어 함수 형식 문자 케이스 변환 단계 Mar 03, 2025 pm 05:53 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 언어 기능의 정의 및 호출 규칙은 무엇이며

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

뚜렷한 사용 및 문구 공유

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

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

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

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

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

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

See all articles