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

这篇博客介绍了在C#中遇到的DataTable行拷贝问题及其解决方案。当尝试将一个DataTable的行添加到另一个DataTable时,出现错误:'该行已经属于另一个表'。作者提供了两种有效的方法:使用DataTable.Rows.Add(DataRow.ItemArray)和DataTable.ImportRow(DataRow),并给出了错误代码和修正后的代码示例。
摘要由CSDN通过智能技术生成

一、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.Ro

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要比较两个 DataTable 中某列的差异,可以使用 LINQ 查询和 `Except()` 方法来实现。 假设我们要比较两个 DataTable `table1` 和 `table2` 中的某一列 `columnName` 的差异,可以按照以下步骤进: 1. 使用 `AsEnumerable()` 方法DataTable 转换为 `IEnumerable<DataRow>`,以便在 LINQ 查询中使用。 2. 使用 `Select()` 方法选择需要比较的列。 3. 使用 `Except()` 方法获取两个中不同的。 下面是示例代码: ```csharp // 获取 table1 和 table2 中不同的 var diff = table1.AsEnumerable() .Select(row => row.Field<string>(columnName)) .Except(table2.AsEnumerable() .Select(row => row.Field<string>(columnName))); // 输出差异 foreach (var val in diff) { Console.WriteLine(val); } ``` 上面的代码首先使用 `Select()` 方法选择了 `columnName` 列,并使用 `AsEnumerable()` 方法DataTable 转换为 `IEnumerable<DataRow>`。然后使用 `Except()` 方法获取两个中不同的,最后输出差异。 需要注意的是,如果两个中包含相同的值但顺序不同,那么这些值将被视为不同,因此你可能需要使用 `OrderBy()` 方法来排序。例如: ```csharp // 获取 table1 和 table2 中不同的 var diff = table1.AsEnumerable() .Select(row => row.Field<string>(columnName)) .OrderBy(val => val) .Except(table2.AsEnumerable() .Select(row => row.Field<string>(columnName)) .OrderBy(val => val)); // 输出差异 foreach (var val in diff) { Console.WriteLine(val); } ``` 这里使用 `OrderBy()` 方法两个的选择结果进排序,以便获取准确的差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值