DataTable詳細(xì)用法

一.DataTable簡(jiǎn)介

(1)構(gòu)造函數(shù)
DataTable() 不帶參數(shù)初始化DataTable 類(lèi)的新實(shí)例。
DataTable(string tableName) 用指定的表名初始化DataTable 類(lèi)的新實(shí)例。
DataTable(string tableName, string tableNamespace) 用指定的表名和命名空間初始化DataTable 類(lèi)的新實(shí)例。
(2) 常用屬性
CaseSensitive 指示表中的字符串比較是否區(qū)分大小寫(xiě)。
ChildRelations 獲取此DataTable 的子關(guān)系的集合。
** Columns 獲取屬于該表的列的集合。**
Constraints 獲取由該表維護(hù)的約束的集合。
** DataSet 獲取此表所屬的DataSet。 **
DefaultView 獲取可能包括篩選視圖或游標(biāo)位置的表的自定義視圖。
HasErrors 獲取一個(gè)值,該值指示該表所屬的DataSet 的任何表的任何行中是否有錯(cuò)誤。
MinimumCapacity 獲取或設(shè)置該表最初的起始大小。該表中行的最初起始大小。默認(rèn)值為 50。
** Rows 獲取屬于該表的行的集合。 **
TableName 獲取或設(shè)置DataTable 的名稱(chēng)。
(3)常用方法
AcceptChanges() 提交自上次調(diào)用AcceptChanges() 以來(lái)對(duì)該表進(jìn)行的所有更改。
BeginInit() 開(kāi)始初始化在窗體上使用或由另一個(gè)組件使用的DataTable。初始化發(fā)生在運(yùn)行時(shí)。
Clear() 清除所有數(shù)據(jù)的DataTable。
Clone()克隆DataTable 的結(jié)構(gòu),包括所有DataTable 架構(gòu)和約束。
EndInit() 結(jié)束在窗體上使用或由另一個(gè)組件使用的DataTable 的初始化。初始化發(fā)生在運(yùn)行時(shí)。
ImportRow(DataRow row)將DataRow 復(fù)制到DataTable 中,保留任何屬性設(shè)置以及初始值和當(dāng)前值。
Merge(DataTable table) 將指定的DataTable 與當(dāng)前的DataTable 合并。
NewRow()創(chuàng)建與該表具有相同架構(gòu)的新DataRow。

二.DataTable使用技巧

  (1)Create a DataTable
     DataTable dt = new DataTable("Table_AX"); 
  (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);  
    (4)Select row
     //Search the second row 如果沒(méi)有賦值,則用is null來(lái)select
     DataRow[] drs = dt.Select("column1 is null");
     DataRow[] drss = dt.Select("column0 = 'AX'"); 
    (5)Copy DataTable include data
     DataTable dtNew = dt.Copy(); 

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

    (7)Operate one row
     //對(duì)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
       //綁定的其實(shí)是DefaultView
      gvTestDataTable.DataSource = dt;
      gvTestDataTable.DataBind();

     (13)judge the DataTable’s Column name is a string
      //判斷一個(gè)字符串是否為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;
    }
數(shù)據(jù)庫(kù)獲取datatable:
                string steSq2 = "SELECT \"產(chǎn)品別\" FROM \"LayoutQCCheck\".\"產(chǎn)品別\"";
                NpgsqlDataAdapter nsd2 = new NpgsqlDataAdapter(steSq2, cn);
                DataSet ds2 = new DataSet();
                nsd2.Fill(ds2);
                dt2 = ds2.Tables[0];

                if(dt2 !=null&&dt2.Rows.Count>0)
                {
                    for (int i = 0; i < dt2.Rows.Count;i++ )
                    {
                        DataRow dr2 = dt2.Rows[i];
                        num1.Add(dr2["產(chǎn)品別"].ToString());
                    }
                }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容