首頁 >後端開發 >C#.Net教程 >DataSet,DataTable與DataRow的複製方法

DataSet,DataTable與DataRow的複製方法

巴扎黑
巴扎黑原創
2016-12-20 09:30:171310瀏覽

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文擋。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn