>백엔드 개발 >C++ >LINQ 왼쪽 조인 및 그룹화 기준에서 하위 레코드를 정확하게 계산하는 방법은 무엇입니까?

LINQ 왼쪽 조인 및 그룹화 기준에서 하위 레코드를 정확하게 계산하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-08 20:21:56943검색

How to Accurately Count Child Records in a LINQ Left Join and Group By?

LINQ – 왼쪽 조인, 그룹화 및 정확한 계산을 위한 팁

복잡한 SQL 쿼리를 LINQ to SQL로 변환하는 것은 때로는 까다로울 수 있습니다. 일반적인 예는 왼쪽 조인을 수행하고 열별로 그룹화하여 특정 조건을 충족하는 레코드 수를 계산하는 것입니다.

다음 SQL 쿼리를 고려해 보세요.

<code class="language-sql">SELECT p.ParentId, COUNT(c.ChildId)
FROM ParentTable p
  LEFT OUTER JOIN ChildTable c ON p.ParentId = c.ChildParentId
GROUP BY p.ParentId</code>

이 쿼리는 ParentTable과 ChildTable이라는 두 테이블에서 ParentId와 일치하는 ChildId 수를 검색합니다.

이를 LINQ to SQL로 변환하려면 먼저 왼쪽 조인을 수행하세요.

<code class="language-csharp">from p in context.ParentTable
join c in context.ChildTable on p.ParentId equals c.ChildParentId into j1</code>

단, COUNT(c.ChildId) 부분은 조심스럽게 다뤄야 합니다. 특별한 고려 사항이 없으면 LINQ에서 생성된 SQL은 항상 COUNT(*)을 반환하므로 예상한 결과를 제공하지 못할 수 있습니다.

일치하는 ChildId 값만 정확하게 계산하려면 into 절 뒤에 다음을 추가하세요.

<code class="language-csharp">from j2 in j1.DefaultIfEmpty()</code>

이렇게 하면 일치하는 하위 레코드가 없는 경우 j2에 null 값이 할당됩니다.

마지막으로 그룹화 및 계산을 수행합니다.

<code class="language-csharp">group j2 by p.ParentId into grouped
select new { ParentId = grouped.Key, Count = grouped.Count(t => t.ChildId != null) }</code>

이 코드는 ParentId별로 그룹화되며 ChildId가 비어 있지 않은 레코드만 계산합니다. 결과는 원래 SQL 쿼리의 형식과 일치하는 ParentId 및 Count 속성이 있는 개체입니다. 이를 통해 하위 레코드가 존재하는 경우만 계산하고 계산 결과의 정확성에 영향을 미치는 왼쪽 조인으로 인해 발생하는 null 값을 방지합니다.

위 내용은 LINQ 왼쪽 조인 및 그룹화 기준에서 하위 레코드를 정확하게 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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