C#两个DataTable拷贝问题:该行已经属于另一个表的解决方法

Posted snf全栈工程师

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#两个DataTable拷贝问题:该行已经属于另一个表的解决方法相关的知识,希望对你有一定的参考价值。

一、DataTable.Rows.Add(DataRow.ItemArray);

二、DataTable.ImportRow(DataRow)

三、设置DataTable的tablename,然后.Rows.Add

第一种方法在项目中用到,确实好用!两种方式都可以自己选择吧,没有什么好坏

----------------------------------------------------------------------------------------------------------------

要把数据从一个DataTable复制到另一个DataTable,执行结果出现c#错误:

该行已经属于另一个表。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.ArgumentException: 该行已经属于另一个表。

错误代码如下:


DataTable sourceTable = null;

sourceTable = GetTest(tableName);

 

if (sourceTable == null)

{

return null;

}

DataTable retTable = new DataTable();

foreach (DataRow dr in sourceTable.Rows)

{

if (dr["主键"].ToString() != "")

{

retTable.Rows.Add(dr);

}

}

后经修改,调试通过,修改后代码如下:


      DataTable sourceTable = null;

sourceTable = GetTest(tableName);

if (sourceTable == null)

{

return null;

}

DataTable retTable = new DataTable();

foreach (DataRow dr in sourceTable.Rows)

{

if (dr["主键"].ToString() != "")

{

retTable.Rows.Add(dr.ItemArray);

}

}

 

以上是关于C#两个DataTable拷贝问题:该行已经属于另一个表的解决方法的主要内容,如果未能解决你的问题,请参考以下文章

System.ArgumentException: 该行已经属于另一个表。看下面代码

C# datatable增加行(datarow)数据为另一个datatable中某行

c# 该行已经属于另一个表

该行已经属于另一个表.怎么解决

C# 该行已经属于还有一个表 的解决方法

DataTable 已经属于另一个 DataSet