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