DataTable sourceTable;
DataTable objectTable;
DatatDataRow sourceRow;
DatatDataRow objectRow;
DataRow tempRow;
DataSet souceDataSet = new DataSet();
復制DataSet
DataSet object = souceDataSet.Copy();//深復制
DataSet object = souceDataSet.Clone();//淺復制,只復制架構
復制DataTable
objectTable = sourceTable .Copy();//深復制
objectTable = sourceTable .Clone();//淺復制,只復制架構
復制DataRow
項目開發中經常遇到這種錯誤-“此行已屬於另一個表” 。導致這個錯誤的語句如下:
objectTable .Rows.Add(SourceDataRow);
分析了一下原因,因為DataRow DataTable 都是傳引用調用的。所以一個行在一個表中了,就不能再增加到另外一個表。
具體方法:
1 ImportRow方法:public void ImportRow( DataRow DataRow);
objectTable = sourceTable.clone();//必須先復制表的架構,使具有相同的的列或關系!
foreach (DataRow oRow in sourceTable)
{
objectTable.ImportRow(oRow);//在objectTable中添加一個新行,並將sourceRow的值復制進去,要求表的結構一樣!
}
_____________________________________________________________________________________________________
2. 循環DataTable的每個列
DataRow aDataRow = objectTable.NewRow();
foreach(DataColumn aDataColumn in sourceTable.Columns)
{
aDataRow [aDataColumn.ColumnName] = sourceTable[i][aDataColumn.ColumnName];
}
objectTable.Rows.Add(aDataRow);
3. 自定義復制
objectTable.Columns.Add ("id");//不需要有一樣的架構,只復制自己需要的列!
Object [] myArry = new Object [1];
foreach (DataRow oRow in sourceTable)
{
tempRow = objectTable.NewRow();//此方法必須調用!
myArry[0] = oRow["id"];//如果myArry中沒有源表中的id列的話就會報錯!
tempRow.ItemArray = myArry;//ItemArray屬性為Object類型數組,根據程序的需要需要可自行復制多個列的數據!
objectTable.Rows.Add(tempRow); //此方法必須調用,否則DataRow中的數據將不能顯示!
}
_____________________________________________________________________________________________________
4. LoadDataRow方法:public DataRow LoadDataRow(Object[] values,bool fAcceptChanges);
Object[] newRow = new Object[3];
// 設置對象數組的值
newRow[0] = "Hello";
newRow[1] = "World";
newRow[2] = "two";
DataRow myRow;
ObjectTable.BeginLoadData();
// 將新行添加到表中
myRow = ObjectTable.LoadDataRow(newRow, true);//標志要設置為true,表示添加新行
ObjectTable.EndLoadData();
該方法比較復雜,如果只是簡單的復制現有行的數據來添加新行的話建議不要采用,具體用法請參看sdk文擋。