DataTable用法總結

2021-06-01 06:15:04 字數 4843 閱讀 1542

在專案中經常用到datatable,如果datatable使用得當,不僅能使程式簡潔實用,而且能夠提高效能,達到事半功倍的效果,現對datatable的使用技巧進行一下總結。

一、datatable簡介   

(1)建構函式

datatable()   不帶引數初始化datatable 類的新例項。

datatable(string tablename)  用指定的表名初始化datatable 類的新例項。

datatable(string tablename, string tablenamespace) 用指定的表名和命名空間初始化datatable 類的新例項。

(2) 常用屬性

casesensitive    指示表中的字串比較是否區分大小寫。

childrelations   獲取此datatable 的子關係的集合。

columns             獲取屬於該錶的列的集合。

constraints        獲取由該錶維護的約束的集合。

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("***", typeof(system.boolean));

//datarow dr = dt_ax.newrow();

//dr["***"] = 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;

DataTable的基本用法

using system.data private datatable dt new datatable 給datatable新增列 private void addcolumn 給datatable新增行 private void addrow 返回符合條件的datarow陣列 private v...

DataTable 的用法簡介

先看示例 put the next line into the declarations section.private system.data.dataset dataset private void makedatatables private void makeparenttable priv...

DataTable方法總結

1 初始化datatable datatable dt1 new datatable dt1.columns.add id typeof int dt1.columns.add names typeof string dt1.columns id unique true dt1.primarykey...