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]);
错误信息是:这一行数据已经属于其他表
你们回答的都对 怎么办?? 最佳答案值能给一个 给谁把?? 展开
DataRow dr=dt.select("id=1");
然后
dt1.Rows.Add(dr[0]);
错误信息是:这一行数据已经属于其他表
你们回答的都对 怎么办?? 最佳答案值能给一个 给谁把?? 展开
6个回答
展开全部
其实好像 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~
你想要的是下面的代码吧
/// <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~
展开全部
Table中得所有数据都复制过去的话,直接实例化一个新表,然后直接赋值过去就行了:datatable dt1=new datatable("bbb"); dt1=dt;
赋值其中的行的话,可以新建一行,然后添加到新表中:
datarow dr1=new dt1.newrow();给dr1赋值后;dt1.rows.add(dr1);
赋值某几个字段和上述方法一样就可以。
赋值其中的行的话,可以新建一行,然后添加到新表中:
datarow dr1=new dt1.newrow();给dr1赋值后;dt1.rows.add(dr1);
赋值某几个字段和上述方法一样就可以。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
dt1.Rows.Add(dr[0]);改成dt1.Rows.Add(dr[0].ItemArray);即可
顺便说下
DataRow dr=dt.select("id=1");//这个你能通过编译 太神奇了
应该这样
DataRow[] dr=dt.select("id=1");
顺便说下
DataRow dr=dt.select("id=1");//这个你能通过编译 太神奇了
应该这样
DataRow[] dr=dt.select("id=1");
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
DataRow[] dr=dt.select("id=1"); 这个应该是数组的
dt1.Rows.Add(dr[0].ItemArray); 这个这样写
dt1.Rows.Add(dr[0].ItemArray); 这个这样写
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
DataTable.Copy()
更多追问追答
追问
大哥 请看清楚题目 谢谢
追答
DataSet.Merge(DataRow[])
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询