zoukankan      html  css  js  c++  java
  • 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);

    }

    }

  • 相关阅读:
    《Flutter实战入门》下拉刷新组件的使用方法
    百度HTTPS认证失败解决方法
    unity踩过的音频坑
    如何解决flutter中gradle慢的问题
    如何在ubuntu里面关掉后台的meteor
    ruby生成随机成绩
    Gemfile分平台加载gem
    sublime text2在windows中以命令行启动
    右键添加 CMD 命令提示符
    修复sublime text系统右键菜单
  • 原文地址:https://www.cnblogs.com/spring_wang/p/5503894.html
Copyright © 2011-2022 走看看