gpt4 book ai didi

c# - Full outer join,在 2 个数据表上,带有列列表

转载 作者:太空狗 更新时间:2023-10-29 19:39:28 24 4
gpt4 key购买 nike

我有2个数据表,我不知道它们的数据列列表。此列表必须在运行时提取,并用于完整的外部连接。

使用这些列时,需要合并2个表之间的列,我需要显示所有数据。

到目前为止我正在做的是

  1. 获取公共(public)列,使用 intersect,并实现 IEqualityComparer
  2. 使用这些列创建一个新数据表,以便将 2 个数据表合并到这个新表中

但是,我在第二步遇到了 Linq 问题。

到目前为止我有:

获取常用列

    // Get common columns    var commonColumns = dt1.Columns.OfType().Intersect(dt2.Columns.OfType(), new DataColumnComparer());

新建数据表

    // Create the result which is going to be sent to the user    DataTable result = new DataTable();    // Add all the columns from both tables    result.Columns.AddRange(    dt1.Columns.OfType()    .Union(dt2.Columns.OfType(), new DataColumnComparer())    .Select(c => new DataColumn(c.Caption, c.DataType, c.Expression, c.ColumnMapping)).ToArray());

如何从运行时提取的数据列列表中动态获得高效的完全外部联接?

最佳答案

这可能对你有用

var commonColumns = dt1.Columns.OfType<DataColumn>().Intersect(dt2.Columns.OfType<DataColumn>(), new DataColumnComparer());
DataTable result = new DataTable();

dt1.PrimaryKey = commonColumns.ToArray();

result.Merge(dt1, false, MissingSchemaAction.AddWithKey);
result.Merge(dt2, false, MissingSchemaAction.AddWithKey);

关于c# - Full outer join,在 2 个数据表上,带有列列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16809875/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com