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

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

Linda Hamilton
풀어 주다: 2025-01-10 11:36:42
원래의
221명이 탐색했습니다.

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 => p.Id, pc => pc.ProdId, (p, pc) => new { p, pc })
    .Join(category, ppc => ppc.pc.CatId, c => c.Id, (ppc, c) => new { ppc, c })
    .Select(m => 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿