我想用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();
答案 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
值的对象,因此它不包含在结果中。
也许你不是故意使用内连接?