C DataTable的詳細使用方法

2021-09-08 17:24:35 字數 4368 閱讀 6831

在專案中經經常使用到

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

**testdatatable.datasource = dt;

**testdatatable.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)

public string convertbetweendatatableandxml_ax(datatable dtneedcoveret)

public datatable convertbetweendatatableandxml_ax(string xml)

C DataTable的詳細使用方法

在專案中經經常使用到 datatable,假設datatable 使用得當,不僅能使程式簡潔有用,並且可以提高效能,達到事半功倍的效果,現對 datatable 的使用技巧進行一下總結。一 datatable 簡單介紹 1 建構函式 datatable 不帶引數初始化 datatable 類的新例項...

C DataTable的詳細使用方法

在專案中經經常使用到 datatable,假設datatable 使用得當,不僅能使程式簡潔有用,並且可以提高效能,達到事半功倍的效果,現對 datatable 的使用技巧進行一下總結。一 datatable 簡單介紹 1 建構函式 datatable 不帶引數初始化 datatable 類的新例項...

C DataTable的詳細使用方法

在專案中經經常使用到 datatable,假設datatable 使用得當,不僅能使程式簡潔有用,並且可以提高效能,達到事半功倍的效果,現對 datatable 的使用技巧進行一下總結。一 datatable 簡單介紹 1 建構函式 datatable 不帶引數初始化 datatable 類的新例項...