C# DataTable的詳細用法[轉]

來源:互聯網
上載者:User

標籤:

原文連結

1、建立表   private DataTable vsDt =new DataTable();

2、清空表中內容(表中的列還在)  vsDt.Clear();  

3、清空表中的列   vsDt.Columns.Clear();

4、表中添加列

vsDt.Columns.Add("BH", typeof(string));

vsDt.Columns.Add("RQ", typeof(string));

5、表中添加空行

 DataRow vsDr = vsDt.NewRow();

假如在添加空行之前,已經往表中添加了N列,那麼此時新加的空行,也帶有這些列。

6、表中添加行   vsDt.Rows.Add(vsDr);  

 

        一、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() 以來對該表進行的所有更改。 
          BeginInit()         開始初始化在表單上使用或由另一個組件使用的DataTable。初始化發生在運行時。

          Clear()               清除所有資料的DataTable。 
          Clone()              複製DataTable 的結構,包括所有DataTable 架構和約束。 
          EndInit()            結束在表單上使用或由另一個組件使用的DataTable 的初始化。初始化發生在運行時。 
          ImportRow(DataRow row)    將DataRow 複製到DataTable 中,保留任何屬性設定以及初始值和當前值。 
          Merge(DataTable table)  將指定的DataTable 與當前的DataTable 合并。 
          NewRow()         建立與該表具有相同架構的新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 如果沒有賦值,則用is null來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
         //對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;
        }

 

在C#中,如果要刪除DataTable中的某一行,大致有以下幾種辦法:

1.如果只是想刪除datatable中的一行,可以用DataRow的delete,但是必須要刪除後讓DataTable知道,所以就要用到.AcceptChanges()方法,原因是這種刪除只是標識性刪除,就像我們通常在資料庫中用到的IsDelete欄位。

Delete()之後需要datatable.AccepteChanges()方法確認完全刪除,因為Delete()只是將相應列的狀態標誌為刪除,還可以通過datatable.RejectChanges()復原,使該行取消刪除。

2.徹底刪除就要用到datatable的.Rows.Remove(DataRow dr)方法,同理也只是刪除一行可以,如果要迴圈刪除請繼續往下看。

3.迴圈徹底刪除就要用.Rows.RemoveAt(int index)方法,所以如果你是foreach的愛好者,在此請你換換口味,還有如果你是for的i++的忠實fans也希望你能換個思維。先看一下上面程式的正向寫法(錯誤的,不可用)

for (int i = 0, j = dt.Rows.Count; i < j; i++){  if (Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID) dt.Rows.RemoveAt(i);}

這個的錯誤在於datatable的RemoveAt()會在刪除後更新dataTable的index,所以你要刪除的index可能已經不是你的符合Convert.ToInt32(dt.Rows[i]["RowID"]) == RowID的index了,甚者還會拋出異常,說你訪問的index不存在。

還是要慎用datatable.Rows.RemoveAt(i),若要刪除多行,可以連續用Delete(),然後採用AccepteChanges()方法確認刪除。

使用select方法:

先把要刪除的記錄標記一下,然後select刪除行,執行個體代碼如下:

for (int i = 0; i < len; i++){  if (((CheckBox)Rp.Items[i].FindControl("CB")).Checked)  { dt.Rows[i]["C0"] = 1;//標記要刪除的記錄  }}foreach (DataRow r in dt.Select("c0=1")){  r.Delete();}Rp.DataSource = dt;Rp.DataBind();

C# DataTable的詳細用法[轉]

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.