要把数据从一个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);
}
}
本文解决了一个在将DataTable数据复制过程中遇到的C#错误:'该行已经属于另一个表'。通过修改代码逻辑,实现了数据的正确复制,并提供了修改前后的对比代码,帮助开发者理解并解决类似问题。
1661

被折叠的 条评论
为什么被折叠?



