其实好像 DataTable dt1=dt.Copy();//就已经复制了dt的结构和数据 只不过操作dt和操作dt1变成一样的,这样不是你想要的目的
你想要的是下面的代码吧
///
/// 执行DataTable中的查询返回新的DataTable
///
/// 源数据DataTable
/// 查询条件
///
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);
赋值某几个字段和上述方法一样就可以。
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"); 这个应该是数组的
dt1.Rows.Add(dr[0].ItemArray); 这个这样写
DataTable.Copy()