2

我有 2 个名为“dst”和“dst2”的数据表。它们位于数据集“urenmat”中。数据的主体在“dst”中。然而,这包含一个名为“werknemer”的列。它包含一个对应于“dst2”中某一行的值。此列名为“数字”。

我需要的是一种左外连接 dst.werknemer 和 dst2.nummer 链接的数据表的方法,并创建一个新的数据表,其中包含链接到“dst.werknemer”的“dst2.naam”以及来自的所有其他列'dst'。

我到处寻找,似乎仍然无法找到我问题的正确答案。几个站点提供了一种在这种情况下使用 LINQ 的方法。我曾尝试使用 LINQ,但我对此并不那么熟练。

我尝试使用 101 个 LINQ 示例: http ://code.msdn.microsoft.com/101-LINQ-Samples-3fb9811b

urenmat = dataset.
dst =  a, b, c, d, werknemer.
dst2 = nummer, naam.

我使用了“101”中的以下代码。

            var query =
            from contact in dst.AsEnumerable()
            join order in dst2.AsEnumerable()
            on contact.Field<string>("werknemer") equals
            order.Field<string>("nummer")
            select new
            {
                a = order.Field<string>("a"),
                b = order.Field<string>("b"),
                c = order.Field<string>("c"),
                d = order.Field<string>("d"),
                naam = contact.Field<decimal>("naam")};

但是,我不知道将“联系人”和“订单”更改为什么,而且我似乎无法找到如何将其再次保存到数据表中。

如果这些是愚蠢的问题,我很抱歉,但我试图自己解决它,但看起来我很愚蠢:P。提前感谢您的帮助!

PS。我正在使用 C# 编码,输入数据集和数据表。

4

1 回答 1

0

如果你想生成一个dst左外连接的投影数据集,dst2你可以使用这个 LINQ 表达式(对不起,我并没有真正使用 LINQ 查询语法,所以你必须改用这个 lambda 语法)。

var query = dst.AsEnumerable()
    .GroupJoin(dst2.AsEnumerable(), x => x.Field<string>("werknemer"), x => x.Field<string>("nummer"), (contact, orders) => new { contact, orders })
    .SelectMany(x => x.orders.DefaultIfEmpty(), (x, order) => new
    {
        a = order.Field<string>("a"),
        b = order.Field<string>("b"),
        c = order.Field<string>("c"),
        d = order.Field<string>("d"),
        naam = x.contact.Field<decimal>("naam")
    });

因为这是一个投影数据集,您不能简单地保存回数据表。如果需要保存,那么您需要加载受影响的行,更新所需的字段,然后保存更改。

// untyped
var row = dst.Rows.Find(keyValue);
// typed
var row = dst.FindBy...(keyValue);

// update the field
row.SetField("a", "some value");
// save only this row's changes
row.AcceptChanges();

// or after all changes to the table have been made, save the table
dst.AcceptChanges();

通常,如果您需要执行(投影)数据的加载和保存,ORM(如实体框架或 LINQ-to-SQL)将是最好的工具。但是,在这种情况下,您使用的是DataTable's,我不确定您是否可以将 ORM 链接到这些(尽管看起来它可能是可能的)。

于 2014-08-20T15:42:27.157 回答