微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 将DataColumn添加到DataTable

我想将数据从dataColumn移动到dataTable中的特定列.我不知道如何指定我想在数据表中添加数据列的列.
foreach (DataColumn col in dt.Columns)
        {
            dt1.Columns.Add(col);
        }

我收到一个异常列’X’已经属于另一个DataTable.

解决方法

您需要复制ColumnName等属性并创建新的DataColumns:
foreach (DataColumn col in dt.Columns)
{
    dt1.Columns.Add(col.ColumnName,col.DataType);
}

添加已属于另一个DataTable的DataColumn时,ArgumentException是有原因的.允许这样做是非常危险的,因为DataTable将reference保存到它们的列,并且每列保持reference到它的DataTable.如果您要将列添加到另一个表中,您的代码迟早会被破坏.

如果您还想将DaTarows复制到新表中:

foreach (DaTarow row in t1.Rows)
{
    var r = t2.Rows.Add();
    foreach (DataColumn col in t2.Columns)
    {
        r[col.ColumnName] = row[col.ColumnName];
    }
}

原文地址:https://www.jb51.cc/csharp/97942.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐