LINQ を使用して左結合、グループ化、および空でないサブレコードのカウントを実装します
SQL では、次のクエリは 2 つのテーブル、ParentTable と ChildTable の間で左結合を実行し、各親レコードに関連付けられた子レコードの数をカウントします。
<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>
次の手順を使用して、このクエリを LINQ to SQL に変換します。
Join
メソッドと DefaultIfEmpty
メソッドを使用して左結合を実行します: <code class="language-csharp">from p in context.ParentTable join c in context.ChildTable on p.ParentId equals c.ChildParentId into j1 from j2 in j1.DefaultIfEmpty()</code>
<code class="language-csharp">group j2 by p.ParentId into grouped</code>
<code class="language-csharp">select new { ParentId = grouped.Key, Count = grouped.Count() }</code>
ただし、上記のコードは、null 値を含む各親レコードの子レコードの合計数を返します。空ではないサブレコードのみをカウントするには、Count
式を次のように変更します。
<code class="language-csharp">select new { ParentId = grouped.Key, Count = grouped.Where(t => t.ChildId != null).Count() }</code>
が空ではない子レコードのみがカウントされるようになります。 最終的な LINQ クエリは SQL クエリのロジックを正確に反映し、空ではないサブレコードを効果的にカウントします。 ChildId
以上がLINQ を使用して左結合、グループ化、非 Null 子レコードのカウントを実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。