程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> DataSet、DataTable、DataRow 復制

DataSet、DataTable、DataRow 復制

編輯:C#入門知識

DataSet、DataTable、DataRow 復制

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

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved