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