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

람다 표현식을 사용하여 LINQ에서 여러 테이블을 조인하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-10 10:58:42256검색

How to Join Multiple Tables in LINQ Using Lambda Expressions?

LINQ Lambda 표현식을 사용하여 여러 테이블 조인

LINQ에서 여러 테이블을 작업할 때 관련 데이터를 수집하기 위해 테이블을 조인해야 할 수도 있습니다. 이는 LINQ의 람다 식을 통해 달성할 수 있습니다.

다음 시나리오를 가정합니다.

  • Product, Category 및 ProductCategory(관련 테이블)에 대한 클래스가 있습니다.
  • 세 테이블을 모두 조인하고 특정 속성으로 다른 개체(CategorizedProducts)를 채우려고 합니다.

다음은 람다 식을 사용하여 조인을 수행하는 코드의 업데이트된 버전입니다.

<code class="language-csharp">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 CategorizedProducts
    {
        ProdId = m.ppc.p.Id, // 或 m.ppc.pc.ProdId
        CatId = m.c.CatId,
        // 其他赋值
    });</code>

이 코드에서는

  • 조인 작업은 지정된 조건에 따라 테이블을 조인합니다.
  • 익명 유형은 연결된 데이터의 중간 표현 역할을 합니다.
  • 선택 작업은 필요한 속성을 CategorizedProducts 개체에 투영합니다.

이 솔루션은 조인 테이블의 모든 속성을 포함하는 단일 클래스를 제공하므로 필요에 따라 CategorizedProducts 개체를 채울 수 있습니다.

위 내용은 람다 표현식을 사용하여 LINQ에서 여러 테이블을 조인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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