1. 程式人生 > >C# DataTable常用方法總結

C# DataTable常用方法總結

在專案中經常用到DataTable,如果DataTable使用得當,不僅能使程式簡潔實用,而且能夠提高效能,達到事半功倍的效果,現對DataTable的使用技巧進行一下總結。

  一、DataTable簡介

    (1)建構函式   

DataTable() 

不帶引數初始化DataTable類的新例項

DataTable(string tableName)

用指定的表名初始化DataTable類的新例項

DataTable(string tableName, string tableNamespace)

用指定的表名和名稱空間初始化DataTable

類的新例項

     (2) 常用屬性 

CaseSensitive 

指示表中的字串比較是否區分大小寫

ChildRelations 

獲取此DataTable的子關係的集合

Columns

獲取屬於該表的列的集合

Constraints

獲取由該表維護的約束的集合

DataSet

獲取此表所屬的DataSet

DefaultView

獲取可能包括篩選檢視或遊標位置的表的自定義檢視

HasErrors

獲取一個值,該值指示該表所屬的DataSet的任何表的任何行中是否有錯誤

MinimumCapacity

獲取或設定該表最初的起始大小。該表中行的最初起始大小。預設值為 50

Rows

獲取屬於該表的行的集合

TableName

獲取或設定DataTable的名稱

     (3)常用方法 

AcceptChanges()

提交自上次呼叫AcceptChanges()以來對該表進行的所有更改

RejectChanges()

方法被呼叫時,仍處於編輯模式的任何行將取消其編輯。新行被移除。已修改的和已刪除的行返回到其原始狀態(DataRowState.Unchanged)

GetChanges()

獲取的副本,該副本包含自上次載入以來或自呼叫

以來對該資料集進行的所有更改。

BeginInit() 

開始初始化在窗體上使用或由另一個元件使用的DataTable。初始化發生在執行時

Clear()

清除所有資料的DataTable

Clone()

克隆DataTable的結構,包括所有DataTable架構和約束

Copy()

複製,具有與該 DataTable相同的結構(表架構和約束)和資料。

注意如果這些類已經過派生,則副本也具有相同的派生類

EndInit() 

結束在窗體上使用或由另一個元件使用的DataTable的初始化。初始化發生在執行時

ImportRow(DataRow row)

DataRow複製到DataTable中,保留任何屬性設定以及初始值和當前值。

Merge(DataTable table) 

將指定的DataTable與當前的DataTable合併

合併操作僅對原始表和要合併的表進行操作。子表不會受到影響或被包括在內。如果某個表具有一個或多個作為關係的一部分定義的子表,則需要分別合併每個子表

NewRow()

建立與該表具有相同架構的新DataRow

  二、DataTable使用技巧

 (1)Createa DataTable

  1. DataTable dt = new DataTable("Table_AX");   

(2)Addcolumns for DataTable

  1. //Method 1
  2. dt.Columns.Add("column0", System.Type.GetType("System.String"));  
  3. //Method 2
  4. DataColumn dc = new DataColumn("column1", System.Type.GetType("System.Boolean"));  
  5. dt.Columns.Add(dc); <strong>  
  6. rong>  

    (3)Add rows for DataTable

  1. //Initialize the row
  2. DataRow dr = dt.NewRow();  
  3. dr["column0"] = "AX";  
  4. dr["column1"] = true;  
  5. dt.Rows.Add(dr);  
  6. //Doesn't initialize the row
  7. DataRow dr1 = dt.NewRow();  
  8. dt.Rows.Add(dr1);   

     (4)Select row

  1. //Search the second row 如果沒有賦值,則用is null來select
  2. DataRow[] drs = dt.Select("column1 is null");  
  3. DataRow[] drss = dt.Select("column0 = 'AX'");   

     (5)Copy DataTable include data

  1. DataTable dtNew = dt.Copy();  

     (6)Copy DataTable only scheme

  1. DataTable dtOnlyScheme = dt.Clone();  

     (7)Operate one row

  1. //對dt的操作
  2. //Method 1
  3. DataRow drOperate = dt.Rows[0];  
  4. drOperate["column0"] = "AXzhz";  
  5. drOperate["column1"] = false;  
  6. //Method 2
  7. drOperate[0] = "AXzhz";  
  8. drOperate[1] = false;  
  9. //Method 3
  10. dt.Rows[0]["column0"] = "AXzhz";  
  11. dt.Rows[0]["column1"] = false;  
  12. //Method 4
  13. dt.Rows[0][0] = "AXzhz";  
  14. dt.Rows[0][1] = false;   

     (8)Evaluate another DataTable's row to currentDatatable

  1. dtOnlyScheme.Rows.Add(dt.Rows[0].ItemArray);   

     (9)Convert to string

  1. System.IO.StringWriter sw = new System.IO.StringWriter();  
  2. System.Xml.XmlTextWriter xw = new System.Xml.XmlTextWriter(sw);  
  3. dt.WriteXml(xw);  
  4. string s = sw.ToString();  

     (10)Filter DataTable

  1. dt.DefaultView.RowFilter = "column1 <> true";  
  2. dt.DefaultView.RowFilter = "column1 = true";  

     (11)Sort row

  1. dt.DefaultView.Sort = "ID ,Name ASC";  
  2. dt=dt.DefaultView.ToTable();  

     (12)Bind DataTable

  1. //繫結的其實是DefaultView
  2. gvTestDataTable.DataSource = dt;  
  3. gvTestDataTable.DataBind();  

     (13)judge the DataTable’s Column name is a string

  1. //判斷一個字串是否為DataTable的列名
  2. dtInfo.Columns.Contains("AX");  

     (14)DataTable convert to XML and XML convert toDataTable

  1. protectedvoid Page_Load(object sender, EventArgs e)  
  2. {  
  3.    DataTable dt_AX = new DataTable();  
  4.    //dt_AX.Columns.Add("Sex", typeof(System.Boolean));
  5.    //DataRow dr = dt_AX.NewRow();
  6.    //dr["Sex"] = true;
  7.    //dt_AX.Rows.Add(dr);
  8.    string xml=ConvertBetweenDataTableAndXML_AX(dt_AX);  
  9.    DataTable dt = ConvertBetweenDataTableAndXML_AX(xml);  
  10. }  
  11. publicstring ConvertBetweenDataTableAndXML_AX(DataTable dtNeedCoveret)  
  12. {  
  13.    System.IO.TextWriter tw = new System.IO.StringWriter();  
  14.    //if TableName is empty, WriteXml() will throw Exception.           
  15.    dtNeedCoveret.TableName=dtNeedCoveret.TableName.Length==0?"Table_AX":dtNeedCoveret.TableName;  
  16.    dtNeedCoveret.WriteXml(tw);  
  17.    dtNeedCoveret.WriteXmlSchema(tw);  
  18.    return tw.ToString();  
  19.  }  
  20. public DataTable ConvertBetweenDataTableAndXML_AX(string xml)  
  21. {  
  22.     System.IO.TextReader trDataTable = new System.IO.StringReader(xml.Substring(0, xml.IndexOf("<?xml")));  
  23.     System.IO.TextReader trSchema = new System.IO.StringReader(xml.Substring(xml.IndexOf("<?xml")));  
  24.     DataTable dtReturn = new DataTable();  
  25.     dtReturn.ReadXmlSchema(trSchema);  
  26.     dtReturn.ReadXml(trDataTable);  
  27.     return dtReturn;  
  28. }