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

C# DataTable的常用用法講解,

編輯:C#入門知識

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() 以來對該表進行的所有更改。
          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;
        }
    復制代碼

(15)在DataTable中執行查詢返回DataTable;

方法1:

復制代碼
// <summary>
// 執行DataTable中的查詢返回新的DataTable
// </summary>
// dt 是源數據DataTable
// condition 是查詢條件

DataTable newdt = new DataTable();
newdt = dt.Clone(); // 克隆dt 的結構,包括所有 dt 架構和約束,並無數據;
DataRow[] rows = dt.Select(conditions); // 從dt 中查詢符合條件的記錄;
foreach (DataRow row in rows)  // 將查詢的結果添加到dt中;
{
       newdt.Rows.Add(row.ItemArray);
}
復制代碼

 

方法2:

復制代碼
DataTable newdt = new DataTable();
newdt=dt.Clone();
DataRow[] dr = dt.Select(condition);
for(int i=0;i<dr.Length;i++)
{
newdt.ImportRow((DataRow)dr[i]);
}
復制代碼

 

方法3:

DataTable newdt = new DataTable();

dt.DefaultView.RowFilter = "conditions";

newdt =dt.DefaultView.ToTable();

 (16)刪除DataTable中的行:

刪除DataTable中的行三種方法:(DataTable.Rows.Remove(DataRow dr)、DataTable.Rows.RemoveAt(i)、DataRow.Delete())

刪除DataTable中的行要注意索引問題,一般有兩種方法:
1】用for循環時,注意計數器初始值為表長,自減循環。DataTable.Rows.RemoveAt(i)就要注意。
2】用DataTable的Select方法,注意該方法的參數是字符串篩選器
3】Delete()之後需要datatable.AccepteChanges()方法確認完全刪除,因為Delete()只是將相應列的狀態標志為刪除,還可以通過datatable.RejectChanges()回滾,使該行取消刪除。若要刪除多行,可以連續用Delete(),然後采用AccepteChanges()方法確認刪除。

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