欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c# datatable用法總結(jié)

 更新時間:2010年09月24日 13:21:45   作者:  
在項目中經(jīng)常用到DataTable,如果DataTable使用得當(dāng),不僅能使程序簡潔實用,而且能夠提高性能,達(dá)到事半功倍的效果,現(xiàn)對DataTable的使用技巧進(jìn)行一下總結(jié)。
一、DataTable簡介
(1)構(gòu)造函數(shù)
DataTable() 不帶參數(shù)初始化DataTable 類的新實例。
DataTable(string tableName) 用指定的表名初始化DataTable 類的新實例。
DataTable(string tableName, string tableNamespace) 用指定的表名和命名空間初始化DataTable 類的新實例。
(2) 常用屬性
CaseSensitive 指示表中的字符串比較是否區(qū)分大小寫。
ChildRelations 獲取此DataTable 的子關(guān)系的集合。
Columns 獲取屬于該表的列的集合。
Constraints 獲取由該表維護(hù)的約束的集合。
DataSet 獲取此表所屬的DataSet。DataSet相關(guān)信息,可見我以前的一篇文章《數(shù)據(jù)訪問(2)-DataSet》
DefaultView 獲取可能包括篩選視圖或游標(biāo)位置的表的自定義視圖。
HasErrors 獲取一個值,該值指示該表所屬的DataSet 的任何表的任何行中是否有錯誤。
MinimumCapacity 獲取或設(shè)置該表最初的起始大小。該表中行的最初起始大小。默認(rèn)值為 50。
Rows 獲取屬于該表的行的集合。
TableName 獲取或設(shè)置DataTable 的名稱。
(3)常用方法
AcceptChanges() 提交自上次調(diào)用AcceptChanges() 以來對該表進(jìn)行的所有更改。
BeginInit() 開始初始化在窗體上使用或由另一個組件使用的DataTable。初始化發(fā)生在運行時。
Clear() 清除所有數(shù)據(jù)的DataTable。
Clone() 克隆DataTable 的結(jié)構(gòu),包括所有DataTable 架構(gòu)和約束。
EndInit() 結(jié)束在窗體上使用或由另一個組件使用的DataTable 的初始化。初始化發(fā)生在運行時。
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 如果沒有賦值,則用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
復(fù)制代碼 代碼如下:

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

相關(guān)文章

  • .Net插件框架Managed Extensibility Framework簡介

    .Net插件框架Managed Extensibility Framework簡介

    這篇文章介紹了.Net插件框架Managed Extensibility Framework,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 剖析ASP.NET MVC的DependencyResolver組件

    剖析ASP.NET MVC的DependencyResolver組件

    這篇文章主要為大家剖析ASP.NET MVC的DependencyResolver組件,感興趣的小伙伴們可以參考一下
    2016-04-04
  • asp.net 將一個圖片以二進(jìn)制值的形式存入Xml文件中的實例代碼

    asp.net 將一個圖片以二進(jìn)制值的形式存入Xml文件中的實例代碼

    這篇文章介紹了將一個圖片以二進(jìn)制值的形式存入Xml文件中的實例代碼,有需要的朋友可以參考一下
    2013-07-07
  • ASP.NET餐飲管理系統(tǒng)制作代碼分享

    ASP.NET餐飲管理系統(tǒng)制作代碼分享

    本文通過圖片+代碼的形式,詳細(xì)的介紹了餐飲管理系統(tǒng)各部分功能及其實現(xiàn)方法。餐飲管理系統(tǒng)的制作必須有一條條理性的思維方可以做好,感興趣的小伙伴們可以參考一下
    2015-09-09
  • Asp.net動態(tài)生成html頁面的方法分享

    Asp.net動態(tài)生成html頁面的方法分享

    這篇文章介紹了Asp.net動態(tài)生成html頁面的方法,有需要的朋友可以參考一下
    2013-10-10
  • 獲取ashx得到的內(nèi)容(已處理好的數(shù)據(jù))

    獲取ashx得到的內(nèi)容(已處理好的數(shù)據(jù))

    獲取ashx得到的內(nèi)容,一般用于ajax的情況比較多一點;重點:ashx頁面?zhèn)鬟^來的就是已經(jīng)處理好的數(shù)據(jù),感興趣的朋有可以參考下啊,希望本文對你學(xué)習(xí)ajax有所幫助
    2013-01-01
  • 基于Unity容器中的對象生存期管理分析

    基于Unity容器中的對象生存期管理分析

    基于Unity容器中的對象生存期管理分析
    2013-04-04
  • 如何將Winform移植到.NET Core 3.0

    如何將Winform移植到.NET Core 3.0

    這篇文章主要介紹了如何將Winform移植到.NET Core 3.0,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • .NET 開源項目Polly的簡單介紹

    .NET 開源項目Polly的簡單介紹

    今天介紹一個 .NET 開源庫:Polly,它是支持 .NET Core 的,目前在 GitHub 的 Star 數(shù)量已經(jīng)超過 7 千,它是一個強大且實用的 .NET 庫。
    2021-06-06
  • .NET中如何將文本文件的內(nèi)容存儲到DataSet

    .NET中如何將文本文件的內(nèi)容存儲到DataSet

    大家在項目中比較多的會對文件進(jìn)行操作,例如文件的上傳下載,文件的壓縮和解壓等IO操作。而在.NET項目中較多的會使用DataSet,DataTable進(jìn)行數(shù)據(jù)的緩存。每一個DataSet都是一個或多個DataTable對象的集合,本文主要介紹的是如何將文本文件的內(nèi)容存儲到DataSet里去。
    2016-12-12

最新評論