国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

C# DataTable的詳細(xì)用法

2019-11-17 03:01:56
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

C# DataTable的詳細(xì)用法

在項(xiàng)目中經(jīng)常用到DataTable,如果DataTable使用得當(dāng),不僅能使程序簡(jiǎn)潔實(shí)用,而且能夠提高性能,達(dá)到事半功倍的效果,現(xiàn)對(duì)DataTable的使用技巧進(jìn)行一下總結(jié)。

一、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;        }

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 临洮县| 邻水| 来凤县| 北海市| 洪洞县| 米林县| 乐业县| 龙岩市| 金坛市| 息烽县| 三门县| 安宁市| 望谟县| 开江县| 乐至县| 文水县| 肥乡县| 故城县| 黔东| 绥滨县| 垦利县| 桑植县| 全州县| 平邑县| 许昌市| 莲花县| 大宁县| 苍梧县| 内丘县| 慈利县| 商南县| 太仆寺旗| 宽甸| 广元市| 合水县| 开原市| 广西| 浏阳市| 宣城市| 左权县| 丹寨县|