2012-05-01 30 views
0

私は、好ましくはLINQ、2つのデータテーブルを照会する方法を理解しようとしています。 私はLEFT OUTERは、COLのでDatatable1 LEFT OUTER JOIN 2 datatables

それらにJOINをやりたい:[ID] [で、colA]
COLさんとDataTable2:[ID] [COLB] [COLC] ...

をするために探してそのIDに参加してください。

誰かが私に持っているデータセットにそれを適用できるように私に例を示してもらえますか?インナーを取得するには、事前

+0

これを試してみましたか:http://msdn.microsoft.com/en-us/library/bb311040.aspxまたはこれも:http://stackoverflow.com/questions/5388969/join-two-tables- in-linq-to-SQL –

答えて

3

ですこれはコンパイルし、何をだろうし与えられた結果セットに基づいて期待してください:

// 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"]}; 
+0

これはうまくいくように見えますが、今は試しています。私のプログラムは最初にデータベースを移植するのに時間がかかりますが、完了したら私は報告します。 ありがとうございました! – Kyle

0

でいただきありがとうございますが、この

from x in Datatable1 
join y in Datatable2 on x.ID equals y.ID 
select new {x.colA, y.ColB, y.ColC } 
+1

私はあなたの例に誰も私が混乱している部分を推測しています。elsesの例では、x.IDはありません。 x.IDがあるはずですか? x.IDの代わりにx.Table.Columns ["ID"]のようなことをしなければならないのでしょうか?私が間違って何をして、私がX.IDを得られないのだろうか?ご協力ありがとうございました。 – Kyle

2

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); 
+0

あなたの例に私が混乱している部分があると思います。誰もが私のためにx.IDはありません。 x.IDがあるはずですか? x.IDの代わりにx.Table.Columns ["ID"]のようなことをする必要がありますか? 私はX.IDを取得しないと何が間違っている可能性がありますか? ご協力いただきありがとうございます。 – Kyle

+0

あなたはこれまで何をしていますか?なぜあなたはx.IDを取得していないのですか? – Turbot

+0

たとえば、最初からできるだけ厳密に試してみてください。 http://codepaste.net/ic84es .AsEnumerable()を使用しないと、DataTable1でGroupJoinが見つからないというエラーが表示されます。 AsEnumerable()を追加した場合、検索中に見つかったサンプルの1つがデータテーブルに対して示した場合、次のエラーは.IDがないためX.IDです。私はちょうどDataRowのために正常であるものを得る。 もう一度ご協力いただきありがとうございます。 – Kyle