复制DataTable数据,c#出错:该行已经属于另一个表

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/erroraspx/article/details/5378404

要把数据从一个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);

                }

            }

 

 

展开阅读全文

没有更多推荐了,返回首页