C#把一个datatable中的数据复制到另一张datatable?

有一个datatabledt;另一个datatabledt1;DataRowdr=dt.select("id=1");然后dt1.Rows.Add(dr[0]);错误信息... 有一个datatable dt;另一个datatable dt1;
DataRow dr=dt.select("id=1");
然后
dt1.Rows.Add(dr[0]);
错误信息是:这一行数据已经属于其他表
你们回答的都对 怎么办?? 最佳答案值能给一个 给谁把??
展开
 我来答
飘零的狐狸
推荐于2017-11-24 · TA获得超过1.8万个赞
知道大有可为答主
回答量:9251
采纳率:77%
帮助的人:2353万
展开全部
其实好像 DataTable dt1=dt.Copy();//就已经复制了dt的结构和数据 只不过操作dt和操作dt1变成一样的,这样不是你想要的目的

你想要的是下面的代码吧

/// <summary>
/// 执行DataTable中的查询返回新的DataTable
/// </summary>
/// <param name="dt">源数据DataTable</param>
/// <param name="condition">查询条件</param>
/// <returns></returns>
public static DataTable GetNewDataTable(DataTable dt, string condition)
{

DataTable newdt = new DataTable();
try
{
newdt = dt.Clone();
DataRow[] dr = dt.Select(condition);
for (int i = 0; i < dr.Length; i++)
{
newdt.ImportRow((DataRow)dr[i]);
}
return newdt;//返回的查询结果
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
return newdt;
}
}

应该是你想要的吧?如果是 要采纳哦 看我打那么多 O(∩_∩)O~
chqing0913
2011-08-22
知道答主
回答量:43
采纳率:0%
帮助的人:8.5万
展开全部
Table中得所有数据都复制过去的话,直接实例化一个新表,然后直接赋值过去就行了:datatable dt1=new datatable("bbb"); dt1=dt;
赋值其中的行的话,可以新建一行,然后添加到新表中:
datarow dr1=new dt1.newrow();给dr1赋值后;dt1.rows.add(dr1);
赋值某几个字段和上述方法一样就可以。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
aplesen
2011-08-22 · TA获得超过687个赞
知道小有建树答主
回答量:860
采纳率:0%
帮助的人:512万
展开全部
dt1.Rows.Add(dr[0]);改成dt1.Rows.Add(dr[0].ItemArray);即可
顺便说下
DataRow dr=dt.select("id=1");//这个你能通过编译 太神奇了
应该这样
DataRow[] dr=dt.select("id=1");
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wsf_hyd
2011-08-22 · 超过32用户采纳过TA的回答
知道答主
回答量:68
采纳率:0%
帮助的人:79.3万
展开全部
DataRow[] dr=dt.select("id=1"); 这个应该是数组的
dt1.Rows.Add(dr[0].ItemArray); 这个这样写
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友2059bc0ea
2011-08-22 · 超过69用户采纳过TA的回答
知道小有建树答主
回答量:156
采纳率:100%
帮助的人:146万
展开全部
DataTable.Copy()
更多追问追答
追问
大哥  请看清楚题目  谢谢
追答
DataSet.Merge(DataRow[])
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式