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