LINQ를 사용하여 다단계 개체 관계에서 효율적으로 데카르트 곱 생성
객체 지향 프로그래밍에는 복잡한 다단계 관계가 포함되는 경우가 많습니다. 다음 예를 고려해보세요:
<code class="language-csharp">class Person { public List<Dog> Dogs { get; set; } } class Dog { public List<Puppy> Puppies { get; set; } } class Puppy { public string Name { get; set; } }</code>
여기서 Person
에는 Dog
이 여러 개 있고, 각 Dog
에는 Puppy
이 여러 개 있습니다. 문제는 각 Puppy
에서 하나의 Dog
을 선택하는 가능한 모든 조합인 데카르트 곱을 생성하는 것입니다.
기존 SQL에서는 조인을 사용합니다. LINQ는 보다 우아한 솔루션을 제공합니다. 고정된 수의 Dog
(컴파일 시 알려짐)의 경우 간단한 LINQ 쿼리로 충분합니다.
<code class="language-csharp">from p1 in dog1.Puppies from p2 in dog2.Puppies from p3 in dog3.Puppies select new { p1, p2, p3 };</code>
다음과 같은 조합이 생성됩니다.
<code>{p11, p21, p31}, {p11, p21, p32}, {p12, p21, p31}, {p12, p21, p32}</code>
그러나 Dog
개수가 동적인 경우(컴파일 시 알 수 없음), 보다 일반화된 접근 방식이 필요합니다. Eric Lippert의 기사(https://www.php.cn/link/f28c49d8be62973ac7716e0b87dae2f9)는 이 시나리오에 대한 강력한 솔루션을 제공합니다.
적절한 CartesianProduct
방법(Lippert의 기사에 설명된 대로)을 사용하면 쿼리가 다음과 같이 단순화됩니다.
<code class="language-csharp">CartesianProduct(from dog in person.Dogs select dog.Puppies);</code>
동일한 결과를 얻습니다. LINQ의 강력한 표현력을 통해 복잡한 다단계 개체 관계를 간결하고 유지 관리 가능하게 처리하여 데카르트 곱 생성을 단순화할 수 있습니다.
위 내용은 LINQ는 어떻게 다단계 개체 관계에서 데카르트 곱을 효율적으로 생성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!