できればLINQ、2つのデータテーブルを使用して、クエリを実行する方法を理解しようとしています。それらにLEFT OUTER JOINを実行したい
列を持つ Datatable1: [ID] [colA]
列を持つ DataTable2: [ID] [ColB] [ColC] ...
そのIDでの参加をお待ちしています。
私が持っているデータテーブルに適用できるように、誰かが私に例を見せてもらえますか? 前もって感謝します
これはコンパイルされ、与えられた結果セットに基づいて期待されることを行います:
// create the default row to be used when no value found
var defaultRow = DataTable2.NewRow();
defaultRow[0] = 0;
defaultRow[1] = String.Empty;
// the query
var result = from x in DataTable1.AsEnumerable()
join y in DataTable2.AsEnumerable() on (string)x["ID"] equals (string)y["ID"]
into DataGroup
from row in DataGroup.DefaultIfEmpty<DataRow>(defaultRow)
select new {a = x["ColA"], b = (string)row["ColB"]};
取得するにはLEFT OUTER Join
@Joannaリンクを使用してみてください。
from x in DataTable1
join y in DataTable2 on x.ID equals y.ID into DataGroup
from item in DataGroup.DefaultIfEmpty(new y.ColB = String.Empty , y.ColC = String.Empty})
select new {x.ColA, item.ColB , item.ColC}
アップデート
あなたが提供するものを考えると、LINQ-データセットの記事を探す必要があります
これがコードスニペットです
DataTable DataTable1 = new DataTable();
DataTable DataTable2 = new DataTable();
DataTable1.Columns.Add("ID");
DataTable1.Columns.Add("ColA");
DataTable1.Rows.Add(1, "A");
DataTable1.Rows.Add(2, "B");
DataTable2.Columns.Add("ID");
DataTable2.Columns.Add("ColB");
DataTable2.Rows.Add(1, "B");
var result = from x in DataTable1.AsEnumerable()
join y in DataTable2.AsEnumerable() on x["ID"] equals y["ID"] into DataGroup
from item in DataGroup.DefaultIfEmpty()
select new {
ID = x["ID"],
ColA = x["ColA"],
ColB = item == null ? string.Empty : item["ColB"]
};
foreach (var s in result)
Console.WriteLine("{0}", s);
内部結合を取得するには、これを試してください
from x in Datatable1
join y in Datatable2 on x.ID equals y.ID
select new {x.colA, y.ColB, y.ColC }