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

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

Linda Hamilton
Linda Hamilton원래의
2025-01-10 11:36:42266검색

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

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