DataSet 物件是支援ADO.NET的斷開式、分散式資料方案的核心對象,用途非常廣泛.我們很多時候需要使用其中的數據,例如取得一個DataTable的資料或複製另一個DataTabe中的資料或是DataRow的數據,但是只有DataSet和DataTable的複製是支援深層複製的,就是說不僅能複製元素的結構,而且能複製元素的數據,而DatatDataRow沒有相關的複製的方法,下面將簡單介紹下這些數據元素的複製問題。
DataTable sourceTable;
DataTable objectTable;
DatatDataRow sourceRow;
DatatDataRow objectRow;
DataRow tempRow
DataSet DataSet.Copy();//深度複製
DataSet object = souceDataSet.Clone();//淺複製,只複製架構
複製DataTable
objectTable = sourceTable .Copy();//深複製
objectTable = sourceTable 複製。
專案開發中經常遇到這種錯誤-「此行已屬於另一個表」 。導致這個錯誤的語句如下:
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中新增一個新行,並且將資料表的資料列複製進去
}
_____________________________________________________________________________________________________
2. 循環DataTable的每個欄位
DataRow aDataRow = objectTable.NewRow();
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中沒有來源表中的id列的話就會報錯!
tempRow.ItemArray = myArry;//ItemArray屬性為Object類型數組,根據程式的需求需要可自行複製多個列的資料!
objectTable.Rows.Add(tempRow); //此方法必須調用,否則DataRow中的資料將無法顯示!
}
_____________________________________________________________________________________________________
4. LoadDataRow方法:public DataRow LoadDataRow(Object[] values,bool fAcceptChanges);
newRow[0] = "Hello";
newRow[1] = "World";
newRow[2] = "two";
// 將新行加入表中
myRow = ObjectTable.LoadDataRow(newRow, true);//標誌要設為true,表示新增一行
ObjectTable.EndLoadData();新行的話建議不要採用,具體用法請參看sdk文擋。