LINQ to SQL: 複数の条件を使用した左外部結合をマスターする
SQL クエリを LINQ to SQL に変換するのは、特に複雑な結合の場合、難しい場合があります。この記事では、複数の条件を使用して左外部結合を実行するという一般的なシナリオに焦点を当てます。
SQL チャレンジ:
私たちの出発点は、「period」テーブルと「facts」テーブルの間の左外部結合を使用する SQL クエリです。 結合では、「p.id = f.periodid」と「f.otherid = 17」という 2 つの条件が使用されます。 2 番目の条件はフィルターとして機能します。
LINQ ハードル:
LINQ の DefaultIfEmpty()
メソッドは、左外部結合の通常のアプローチです。ただし、結合のwhere
後に 'f.otherid = 17' を 句に追加するだけでは期待どおりに機能しません。
効果的な LINQ ソリューション:
重要なのは、 を使用して 2 番目の結合条件を 前DefaultIfEmpty()
に適用することです。 ここでは 2 つの効率的な方法を紹介します:
方法 1: 拡張メソッド構文を使用する:
<code class="language-csharp">from p in context.Periods join f in context.Facts on p.id equals f.periodid into fg from fgi in fg.Where(f => f.otherid == 17).DefaultIfEmpty() where p.companyid == 100 select fgi.value</code>
方法 2: サブクエリの使用:
<code class="language-csharp">from p in context.Periods join f in context.Facts on p.id equals f.periodid into fg from fgi in (from f in fg where f.otherid == 17 select f).DefaultIfEmpty() where p.companyid == 100 select fgi.value</code>
これが機能する理由:
決定的な違いは、条件の配置にあります。 where
句の after DefaultIfEmpty()
に 'f.otherid == 17' を入れると、'f' が null の行がフィルターで除外されます (結合で一致が見つからなかったため)。 これを Where()
句の before DefaultIfEmpty()
内に配置することで、null 値が導入される 前 にフィルタリングし、正しい左外部結合動作を保証します。 最初のメソッドで null を正しく処理するには、fgi.value
ではなく f.value
を選択することに注意してください。
以上がLINQ to SQLで複数の条件を使用して左外部結合を実行する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。