7

所以我有两个具有相同架构但数据不同的数据表。我想将两个表连接在一起,其中两个字段 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 列上将这两个表连接在一起?

问候,

凯尔

4

1 回答 1

14

使用匿名对象加入多个字段:

    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")
        };

请记住,匿名对象属性名称应该匹配。

于 2013-11-06T13:48:58.400 回答