我想将数据从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];
}
}