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

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

Barbara Streisand
リリース: 2024-12-29 20:02:15
オリジナル
529 人が閲覧しました

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

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート