ホームページ >バックエンド開発 >C++ >LINQ to SQL で複数の結合条件を使用して左外部結合を実行するにはどうすればよいですか?

LINQ to SQL で複数の結合条件を使用して左外部結合を実行するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-29 20:02:15545ブラウズ

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

LINQ to SQL: 複数の結合条件による左外部結合の強化

LINQ to SQL では、左外部結合は結合のための強力なメカニズムを提供します。複数のテーブルからのデータ。ただし、追加の結合条件を含むシナリオを扱う場合は、標準的なアプローチを拡張する手法を検討する必要があります。

SQL クエリを考えてみましょう。

SELECT f.value
FROM period as p 
LEFT OUTER JOIN facts AS f ON p.id = f.periodid AND f.otherid = 17
WHERE p.companyid = 100

このクエリは、次のクエリからデータを取得しようとしています。 「period」テーブルと「facts」テーブル。「id」列と「periodid」列に左外部結合を適用します。さらに、結果をフィルタリングするための追加の結合条件「f.otherid = 17」が含まれています。

LINQ to SQL では、左外部結合の一般的な実装には、「DefaultIfEmpty()」メソッドの使用が含まれます。 。ただし、追加の結合条件に対応するには、アプローチを変更する必要があります。

次の LINQ クエリにより、望ましい結果が得られます。

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 f.value

ここでは、 「.Where()」句。「fg」グループからの行の選択が「f.otherid =」に基づいてフィルタリングされることを保証します。 17'.

代わりに、サブクエリを利用することもできます。

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 f.value

どちらのアプローチでも、追加の結合条件を適用しながら左外部結合を正常に実行できるため、よりターゲットを絞ったデータの取得が可能になります。

以上がLINQ to SQL で複数の結合条件を使用して左外部結合を実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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