C#把一个datatable中的数据复制到另一张datatable?
发布网友
发布时间:2022-04-27 17:27
我来回答
共7个回答
懂视网
时间:2022-04-27 21:48
将DataTable中的一行复制到另一个DataTable
方法1:
DataRow dr = ds2.Tables[0].NewRow();
dr.ItemArray = ds1.Tables[0].Rows[i].ItemArray;
ds2.Tables[0].Rows.Add( dr );
方法2:
ds2.Tables[0].ImportRow(ds1.Tables[0].Rows[i]);
热心网友
时间:2022-04-27 18:56
其实好像 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~
热心网友
时间:2022-04-27 20:14
Table中得所有数据都复制过去的话,直接实例化一个新表,然后直接赋值过去就行了:datatable dt1=new datatable("bbb"); dt1=dt;
赋值其中的行的话,可以新建一行,然后添加到新表中:
datarow dr1=new dt1.newrow();给dr1赋值后;dt1.rows.add(dr1);
赋值某几个字段和上述方法一样就可以。
热心网友
时间:2022-04-27 21:49
dt1.Rows.Add(dr[0]);改成dt1.Rows.Add(dr[0].ItemArray);即可
顺便说下
DataRow dr=dt.select("id=1");//这个你能通过编译 太神奇了
应该这样
DataRow[] dr=dt.select("id=1");
热心网友
时间:2022-04-27 23:40
DataRow[] dr=dt.select("id=1"); 这个应该是数组的
dt1.Rows.Add(dr[0].ItemArray); 这个这样写
热心网友
时间:2022-04-28 01:48
DataTable.Copy()
热心网友
时间:2022-04-28 04:13
是不是用了表连接啊!追问这是C#的问题 不是数据库,C#里面有表连接么?
追答那就不知道,我也只是猜测而已