C#两个DataTable拷贝问题:该行已经属于另一个表的解决方法
2016-05-18 08:14
639 查看
一、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);
}
}
二、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# 笔记——排序
- C# 笔记——数据类型
- C#系统命名空间[精心整理的…
- C#添加WebService服务实现天气预报(查询)
- ●c#使用正则表达式
- C# 委托(Delegate Action Func Predicate)
- C#系统硬件类列表
- NetAnalyzer笔记 之 十 贫民的选择 —— 通过邮件方式打造自己的bug反馈模块(C#)
- Quartz.NET c# 教程 - 课程三:Jobs 和 JobDetails
- C#装箱和拆箱(Boxing 和 UnBoxing)
- C#Winform判断文件和路径是否存在
- WCF服务寄宿IIS与Windows服务 - C#/.NET
- c# DataTable遍历
- C#当前日期时间
- C# 转换时间戳
- 第3章 C# 程序的流程控制
- C#学习笔记
- c#打包安装程序默认安装路径设置
- C#:绘制Winform窗体
- C#视频播放器