[解決済み] LINQのOn句で複数条件を指定してのJoin
2022-09-26 05:58:34
質問
LINQで、ON句に複数の条件を含む左外部結合を使用するクエリを実装しようとしています。
次の2つのテーブルを例にしてみます。 プロジェクト (ProjectID、ProjectName) と タスク (TaskID、ProjectID、TaskName、Completed)の2種類があります。私は、すべてのプロジェクトとそれぞれのタスクの完全なリストを見たいのですが、完了したタスクだけが表示されます。
に対するフィルターは使用できません。
Completed == true
に対するフィルタは使えません。完了したタスクがないプロジェクトはフィルタリングされてしまうからです。代わりに
Completed == true
を結合のON句に追加して、プロジェクトの全リストを表示し、完了したタスクのみを表示するようにします。完了したタスクがないプロジェクトでは、TaskにNull値を指定した1行が表示されます。
ここにクエリの基礎があります。
from t1 in Projects
join t2 in Tasks
on new { t1.ProjectID} equals new { t2.ProjectID } into j1
from j2 in j1.DefaultIfEmpty()
select new { t1.ProjectName, t2.TaskName }
どのようにすれば
&& t2.Completed == true
をon節に追加するには?
これを行う方法について、LINQのドキュメントを見つけることができないようです。
どのように解決するのですか?
匿名プロパティの名前を双方で同じにするだけです。
on new { t1.ProjectID, SecondProperty = true } equals
new { t2.ProjectID, SecondProperty = t2.Completed } into j1
svickのコメントに基づいて、より理にかなった別の実装を紹介します。
from t1 in Projects
from t2 in Tasks.Where(x => t1.ProjectID == x.ProjectID && x.Completed == true)
.DefaultIfEmpty()
select new { t1.ProjectName, t2.TaskName }
関連
-
[解決済み] LINQで複数の "order by "を使用する
-
[解決済み] JOINとINNER JOINの違いについて
-
[解決済み] LINQのGroup by
-
[解決済み] INNER JOIN ON vs WHERE句
-
[解決済み] SQL JOIN - WHERE句とON句の比較
-
[解決済み] LINQとLambdaでJoin/Whereを実現する
-
[解決済み】「INNER JOIN」と「OUTER JOIN」の違いは何ですか?
-
[解決済み】Lambda式でOrderBy descending?
-
[解決済み】LINQで1回の結合で複数フィールドの結合を行う方法
-
[解決済み] LINQ-to-SQLとストアドプロシージャの比較?[クローズド]
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] IEnumerable<T>のforeachのLINQでの等価性
-
[解決済み】Lambda式でOrderBy descending?
-
[解決済み】Entity Framework。このコマンドに関連するオープンなDataReaderがすでに存在します。
-
[解決済み] エンティティフレームワークのLinqクエリInclude()複数の子エンティティ
-
[解決済み] LINQ-to-SQLとストアドプロシージャの比較?[クローズド]
-
[解決済み] LINQ を使用して、オブジェクトのリストから一意のプロパティのリストを取得するにはどうすればよいですか?
-
[解決済み] LINQを使用してデータをPivotすることは可能ですか?
-
[解決済み] Linqのgroup byのカウントを持つ
-
[解決済み] 指定された型メンバー 'Date' は LINQ to Entities でサポートされていません。イニシャライザ、エンティティ・メンバ、およびエンティティ・ナビゲーション・プロパティのみです。
-
[解決済み] LINQ: 区分された値