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