C#Linq加入2个表

时间:2012-09-19 09:12:54

标签: c# linq join dataset

我想用linq或DataRelation加入2个表。所以我首先尝试使用linq,它工作得很好,但是当我将另一个对象添加到1. Tables并与2.Table连接时,它不显示此对象。

这是我的代码:

DataTable table = new DataTable("Kunde");

table.Columns.Add("KundeID", typeof(Int32));
table.Columns.Add("KundeName", typeof(String));
table.Columns.Add("Produkt", typeof(String));

table.PrimaryKey = new DataColumn[] { table.Columns["KundeID"] };

DataTable comment = new DataTable("Comment"); 

comment.Columns.Add("KundeName", typeof(String));
comment.Columns.Add("Comment", typeof(String));

comment.PrimaryKey = new DataColumn[] { comment.Columns["KundeName"] };


DataSet ds = new DataSet("DataSet");

ds.Tables.Add(table);
ds.Tables.Add(comment);

object[] o1 = { 1, "Michael", "Jogurt" };
object[] o2 = { 2, "Raj", "Cola" };
object[] o3 = { 3, "Gary", "Fanta" };
***object[] o4 = { 4, "Miky", "Sprite" };***

object[] c1 = { "Raj", "Ich bin cool" };
object[] c2 = { "Gary", "yahoo" };
object[] c3 = { "Michael", "nichts zu verlieren" };


table.Rows.Add(o1);
table.Rows.Add(o2);
table.Rows.Add(o3);
table.Rows.Add(o4);

comment.Rows.Add(c1);
comment.Rows.Add(c2);
comment.Rows.Add(c3);

var results = from table1 in table.AsEnumerable()
              join table2 in comment.AsEnumerable()
              on table1.Field<string>("KundeName") equals table2.Field<string>("KundeName")
              select new
                  {
                      KundeID = table1.Field<Int32?>("KundeID"),
                      KundeName = table1.Field<String>("KundeName"),
                      Produkt = table1.Field<String>("Produkt"),

                      Comment = table2.Field<String>("Comment")
                  };

foreach (var item in results)
{
    Console.WriteLine(String.Format("{0}    {1}    {2}    {3}", item.KundeID, item.KundeName, item.Produkt, item.Comment));
}


Console.ReadKey();

2 个答案:

答案 0 :(得分:3)

如果您需要第一个表中的所有行,无论它们是否可以连接到第二个表中的行,您需要左连接:

    var results = from table1 in table.AsEnumerable()
                  join table2 in comment.AsEnumerable()
                  on table1.Field<string>("KundeName") equals table2.Field<string>("KundeName") into joined
                  from table3 in joined.DefaultIfEmpty()
                  select new
                      {
                          KundeID = table1.Field<Int32?>("KundeID"),
                          KundeName = table1.Field<String>("KundeName"),
                          Produkt = table1.Field<String>("Produkt"),

                          Comment = table3 != null ? table3.Field<String>("Comment") : null
                      };

通过这种方式,您可以获得名为“Miky”的客户端,但他的Comment将为空。

答案 1 :(得分:0)

您的o4对象在comment中没有一个具有匹配KundeName值的对象,因此它不包含在结果中。

也许你不是故意使用内连接?