所以我有两个具有相同模式但数据不同的DataTable。我想将两个表连接在一起,其中两个字段,id3和print相同。我如何在LINQ中写这个?
现在,这可以工作并且不会产生编译错误:
var singOneJoin =
from prod in singOneProd.Table.AsEnumerable()
join agg in singOneAgg.Table.AsEnumerable()
on prod.Field<string>("print") equals agg.Field<string>("print")
select new
{
print = prod.Field<string>("print")
};
但我真正想要的是:
var singOneJoin =
from prod in singOneProd.Table.AsEnumerable()
join agg in singOneAgg.Table.AsEnumerable()
on (prod.Field<string>("print") equals agg.Field<string>("print") &&
prod.Field<Int32>("id3") equals agg.Field<Int32><("id3"))
select new
{
print = prod.Field<string>("print")
};
但这给了我编译错误。
如何在print和id3列上将这两个表连接在一起?
此致
凯尔
答案 0 :(得分:12)
使用匿名对象加入多个字段:
var singOneJoin =
from prod in singOneProd.Table.AsEnumerable()
join agg in singOneAgg.Table.AsEnumerable()
on new {
Print = prod.Field<string>("print"),
Id3 = prod.Field<Int32>("id3")
} equals new {
Print = agg.Field<string>("print"),
Id3 = agg.Field<Int32>("id3")
}
select new {
print = prod.Field<string>("print")
};
请记住,匿名对象属性名称应匹配。