ホームページ >データベース >mysql チュートリアル >LINQ to SQLで複数の条件を使用して左外部結合を実行する方法は?

LINQ to SQLで複数の条件を使用して左外部結合を実行する方法は?

Patricia Arquette
Patricia Arquetteオリジナル
2025-01-12 09:58:41456ブラウズ

How to Perform a Left Outer Join with Multiple Conditions in LINQ to SQL?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。