がLEFT OUTER Join
を取得しようと参加すると、あなたは@Joannaリンクを使用してみてください。あなたはここでLINQ-データセットの記事
を探す必要があります提供するものを考える
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}
UPDATE
は、コードスニペットが
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);
これを試してみましたか:http://msdn.microsoft.com/en-us/library/bb311040.aspxまたはこれも:http://stackoverflow.com/questions/5388969/join-two-tables- in-linq-to-SQL –