C# DataTable的詳細用法 (轉)

在項目中常常用到DataTable,若是DataTable使用得當,不只能使程序簡潔實用,並且可以提升性能,達到事半功倍的效果,現對DataTable的使用技巧進行一下總結。 sql

        1、DataTable簡介    架構

          (1)構造函數 
          DataTable()   不帶參數初始化DataTable 類的新實例。 
          DataTable(string tableName)  用指定的表名初始化DataTable 類的新實例。 
          DataTable(string tableName, string tableNamespace) 用指定的表名和命名空間初始化DataTable 類的新實例。 
          (2) 經常使用屬性 
          CaseSensitive    指示表中的字符串比較是否區分大小寫。 
          ChildRelations   獲取此DataTable 的子關係的集合。 
          Columns             獲取屬於該表的列的集合。 
          Constraints        獲取由該表維護的約束的集合。 
          DataSet               獲取此表所屬的DataSet。DataSet相關信息,可見我之前的一篇文章《數據訪問(2)-DataSet》 
          DefaultView       獲取可能包括篩選視圖或遊標位置的表的自定義視圖。 
          HasErrors          獲取一個值,該值指示該表所屬的DataSet 的任何表的任何行中是否有錯誤。 
          MinimumCapacity  獲取或設置該表最初的起始大小。該表中行的最初起始大小。默認值爲 50。 
          Rows                  獲取屬於該表的行的集合。 
          TableName       獲取或設置DataTable 的名稱。 函數

          (3)經常使用方法 
          AcceptChanges()   提交自上次調用AcceptChanges() 以來對該表進行的全部更改。 
          BeginInit()         開始初始化在窗體上使用或由另外一個組件使用的DataTable。初始化發生在運行時。性能

          Clear()               清除全部數據的DataTable。 
          Clone()              克隆DataTable 的結構,包括全部DataTable 架構和約束。 
          EndInit()            結束在窗體上使用或由另外一個組件使用的DataTable 的初始化。初始化發生在運行時。 
          ImportRow(DataRow row)    將DataRow 複製到DataTable 中,保留任何屬性設置以及初始值和當前值。 
          Merge(DataTable table)  將指定的DataTable 與當前的DataTable 合併。 
          NewRow()         建立與該表具備相同架構的新DataRow。
 
        2、DataTable使用技巧lua

      (1)Create a DataTable
         DataTable dt = new DataTable("Table_AX"); spa

      (2)Add columns for DataTable
        //Method 1
        dt.Columns.Add("column0", System.Type.GetType("System.String"));
        //Method 2
        DataColumn dc = new DataColumn("column1", System.Type.GetType("System.Boolean"));
        dt.Columns.Add(dc); 

       (3)Add rows for DataTable
         //Initialize the row
         DataRow dr = dt.NewRow();
         dr["column0"] = "AX";
         dr["column1"] = true;
         dt.Rows.Add(dr);
         //Doesn't initialize the row
         DataRow dr1 = dt.NewRow();
         dt.Rows.Add(dr1);  xml

        (4)Select row
         //Search the second row 若是沒有賦值,則用is null來select
         DataRow[] drs = dt.Select("column1 is null");
         DataRow[] drss = dt.Select("column0 = 'AX'"); ci

        (5)Copy DataTable include data
         DataTable dtNew = dt.Copy(); 

        (6)Copy DataTable only scheme
         DataTable dtOnlyScheme = dt.Clone(); 

        (7)Operate one row
         //對dt的操做
         //Method 1
         DataRow drOperate = dt.Rows[0];
         drOperate["column0"] = "AXzhz";
         drOperate["column1"] = false;
         //Method 2
         drOperate[0] = "AXzhz";
         drOperate[1] = false;
         //Method 3
         dt.Rows[0]["column0"] = "AXzhz";
         dt.Rows[0]["column1"] = false;
         //Method 4
         dt.Rows[0][0] = "AXzhz";
         dt.Rows[0][1] = false; 

       (8)Evaluate another DataTable's row to current Datatable
         dtOnlyScheme.Rows.Add(dt.Rows[0].ItemArray); 

       (9)Convert to string
         System.IO.StringWriter sw = new System.IO.StringWriter();
         System.Xml.XmlTextWriter xw = new System.Xml.XmlTextWriter(sw);
         dt.WriteXml(xw);
         string s = sw.ToString();

        (10)Filter DataTable
         dt.DefaultView.RowFilter = "column1 <> true";
         dt.DefaultView.RowFilter = "column1 = true";

        (11)Sort row
          dt.DefaultView.Sort = "ID ,Name ASC";
          dt=dt.DefaultView.ToTable();

         (12)Bind DataTable
           //綁定的實際上是DefaultView
          gvTestDataTable.DataSource = dt;
          gvTestDataTable.DataBind();

         (13)judge the DataTable’s Column name is a string
          //判斷一個字符串是否爲DataTable的列名
         dtInfo.Columns.Contains("AX");

         (14)DataTable convert to XML and XML convert to DataTable
          protected void Page_Load(object sender, EventArgs e)
          {
             DataTable dt_AX = new DataTable();
             //dt_AX.Columns.Add("Sex", typeof(System.Boolean));
             //DataRow dr = dt_AX.NewRow();
             //dr["Sex"] = true;
             //dt_AX.Rows.Add(dr);
             string xml=ConvertBetweenDataTableAndXML_AX(dt_AX);
             DataTable dt = ConvertBetweenDataTableAndXML_AX(xml);
         }
         public string ConvertBetweenDataTableAndXML_AX(DataTable dtNeedCoveret)
        {
             System.IO.TextWriter tw = new System.IO.StringWriter();
             //if TableName is empty, WriteXml() will throw Exception.                 字符串

dtNeedCoveret.TableName=dtNeedCoveret.TableName.Length==0?"Table_AX":dtNeedCoveret.TableName;
             dtNeedCoveret.WriteXml(tw);
             dtNeedCoveret.WriteXmlSchema(tw);
             return tw.ToString();
        }
         public DataTable ConvertBetweenDataTableAndXML_AX(string xml)
        {
             System.IO.TextReader trDataTable = new System.IO.StringReader(xml.Substring(0, xml.IndexOf("<?xml")));
             System.IO.TextReader trSchema = new System.IO.StringReader(xml.Substring(xml.IndexOf("<?xml")));
             DataTable dtReturn = new DataTable();
             dtReturn.ReadXmlSchema(trSchema);
             dtReturn.ReadXml(trDataTable);
             return dtReturn;
        }string

 

 

  • dt.Compute("sum(SaleNum)""true") ; // 對列SaleNum 彙總支持因此sql 聚合函數 如:sum(),count(),avg()等等。。。
相關文章
相關標籤/搜索