1. ホーム
  2. linq

[解決済み] 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 }