天天看點

DataSet,DataTable與DataRow的複制方法

DataSet 對象是支援 ADO.NET的斷開式、分布式資料方案的核心對象 ,用途非常廣泛.我們很多時候需要使用其中的資料,比如取得一個DataTable的資料或者複制另一個DataTabe中的資料或者是DataRow的資料,但是隻有DataSet和DataTable的複制是支援深層複制的,就是說不僅能複制元素的結構,而且能複制元素的資料,而DatatDataRow沒有相關的複制的方法,下面将簡單介紹下這些資料元素的複制問題。

複制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);      
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中的資料将不能顯示!

}      
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();