我想了解如何查詢,最好是LINQ,2個數據表。 我願做一個LEFT OUTER JOIN他們LEFT OUTER JOIN 2 datatables
Datatable1與山口的:[ID] [可口可樂]
DataTable2與山口的:[ID] [COLB] [COLC] ...
展望加入該ID。
有人可以告訴我一個例子,所以我可以將它應用到我有的數據表中嗎?謝謝你在前進
我想了解如何查詢,最好是LINQ,2個數據表。 我願做一個LEFT OUTER JOIN他們LEFT OUTER JOIN 2 datatables
Datatable1與山口的:[ID] [可口可樂]
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"]};
這看起來像它會工作,我現在正在嘗試它。我的程序最初需要一些時間來填充數據庫,但是一旦完成,我會回報。 非常感謝您的幫助! – Kyle
爲了得到一個內部聯接嘗試這種
from x in Datatable1
join y in Datatable2 on x.ID equals y.ID
select new {x.colA, y.ColB, y.ColC }
我想你的例子讓我感到困惑的一部分,而且每個人都是這樣的例子,我沒有x.ID。應該有一個x.ID?或者我應該做一些像x.Table.Columns [「ID」]而不是x.ID?我可能做錯了,我沒有得到X.ID?感謝您的幫助。 – Kyle
要獲得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}
UPDATE
鑑於你提供你應該尋找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);
我想你的例子讓我感到困惑的一部分,並且每個人都是這樣的例子,我沒有x.ID。應該有一個x.ID? 或者我應該做一些像x.Table.Columns [「ID」]而不是x.ID? 我可能做錯了,我沒有得到X.ID? 謝謝你的幫助。 – Kyle
到目前爲止你做了什麼?你能告訴我們更多爲什麼你沒有得到x.ID? – Turbot
例如,這裏是一開始的代碼,儘可能接近地嘗試和匹配你的代碼。 http://codepaste.net/ic84es 如果我不使用.AsEnumerable(),那麼它會給我一個DataTable1上的錯誤,說沒有找到GroupJoin。 如果我添加AsEnumerable()時發現搜索時發現的示例中的哪個示例爲datatables,那麼下一個錯誤是X.ID,因爲沒有.ID。我只知道DataRow的正常情況。 再次感謝您的幫助。 – Kyle
你有沒有試過這個:http://msdn.microsoft.com/en-us/library/bb311040.aspx或甚至:http://stackoverflow.com/questions/5388969/join-two-tables- in-linq-to-sql –