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
- DataTable dt = new DataTable("Table_AX");
(2)Addcolumns 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); <strong>
- rong>
(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 currentDatatable
- 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 toDataTable
- protectedvoid 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);
- }
- publicstring 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;
- }