熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> .NET編程 >> 正文

c# datatable用法總結

2022-06-13   來源: .NET編程 

  在項目中經常用到DataTable如果DataTable使用得當不僅能使程序簡潔實用而且能夠提高性能達到事半功倍的效果現對DataTable的使用技巧進行一下總結

  一DataTable簡介

  ()構造函數

  DataTable()   不帶參數初始化DataTable 類的新實例

  DataTable(string tableName)  用指定的表名初始化DataTable 類的新實例

  DataTable(string tableName string tableNamespace) 用指定的表名和命名空間初始化DataTable 類的新實例

  () 常用屬性

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

  ChildRelations   獲取此DataTable 的子關系的集合

  Columns             獲取屬於該表的列的集合

  Constraints        獲取由該表維護的約束的集合

  DataSet               獲取此表所屬的DataSetDataSet相關信息可見我以前的一篇文章《數據訪問()-DataSet》

  DefaultView       獲取可能包括篩選視圖或游標位置的表的自定義視圖

  HasErrors          獲取一個值該值指示該表所屬的DataSet 的任何表的任何行中是否有錯誤

  MinimumCapacity  獲取或設置該表最初的起始大小該表中行的最初起始大小默認值為

  Rows                  獲取屬於該表的行的集合

  TableName       獲取或設置DataTable 的名稱

  ()常用方法

  AcceptChanges()   提交自上次調用AcceptChanges() 以來對該表進行的所有更改

  BeginInit()         開始初始化在窗體上使用或由另一個組件使用的DataTable初始化發生在運行時

  Clear()               清除所有數據的DataTable

  Clone()              克隆DataTable 的結構包括所有DataTable 架構和約束

  EndInit()            結束在窗體上使用或由另一個組件使用的DataTable 的初始化初始化發生在運行時

  ImportRow(DataRow row)    將DataRow 復制到DataTable 中保留任何屬性設置以及初始值和當前值

  Merge(DataTable table)  將指定的DataTable 與當前的DataTable 合並

  NewRow()         創建與該表具有相同架構的新DataRow

  二DataTable使用技巧

  ()Create a DataTable

  DataTable dt = new DataTable(Table_AX);

  ()Add columns for DataTable

  //Method

  dtColumnsAdd(column SystemTypeGetType(SystemString));

  //Method

  DataColumn dc = new DataColumn(column SystemTypeGetType(SystemBoolean));

  dtColumnsAdd(dc);

  ()Add rows for DataTable

  //Initialize the row

  DataRow dr = dtNewRow();

  dr[column] = AX;

  dr[column] = true;

  dtRowsAdd(dr);

  //Doesnt initialize the row

  DataRow dr = dtNewRow();

  dtRowsAdd(dr);

  ()Select row

  //Search the second row 如果沒有賦值則用is null來select

  DataRow[] drs = dtSelect(column is null);

  DataRow[] drss = dtSelect(column = AX);

  ()Copy DataTable include data

  DataTable dtNew = dtCopy();

  ()Copy DataTable only scheme

  DataTable dtOnlyScheme = dtClone();

  ()Operate one row

  //對dt的操作

  //Method

  DataRow drOperate = dtRows[];

  drOperate[column] = AXzhz;

  drOperate[column] = false;

  //Method

  drOperate[] = AXzhz;

  drOperate[] = false;

  //Method

  dtRows[][column] = AXzhz;

  dtRows[][column] = false;

  //Method

  dtRows[][] = AXzhz;

  dtRows[][] = false;

  ()Evaluate another DataTables row to current Datatable

  dtOnlySchemeRowsAdd(dtRows[]ItemArray);

  ()Convert to string

  SystemIOStringWriter sw = new SystemIOStringWriter();

  SystemXmlXmlTextWriter xw = new SystemXmlXmlTextWriter(sw);

  dtWriteXml(xw);

  string s = swToString();

  ()Filter DataTable

  dtDefaultViewRowFilter = column <> true;

  dtDefaultViewRowFilter = column = true;

  ()Sort row

  dtDefaultViewSort = ID Name ASC;

  dt=dtDefaultViewToTable();

  ()Bind DataTable

  //綁定的其實是DefaultView

  gvTestDataTableDataSource = dt;

  gvTestDataTableDataBind();

  ()judge the DataTables Column name is a string

  //判斷一個字符串是否為DataTable的列名

  dtInfoColumnsContains(AX);

  ()DataTable convert to XML and XML convert to DataTable

  protected void Page_Load(object sender EventArgs e)

  {

  DataTable dt_AX = new DataTable();

  //dt_AXColumnsAdd(Sex typeof(SystemBoolean));

  //DataRow dr = dt_AXNewRow();

  //dr[Sex] = true;

  //dt_AXRowsAdd(dr);

  string xml=ConvertBetweenDataTableAndXML_AX(dt_AX);

  DataTable dt = ConvertBetweenDataTableAndXML_AX(xml);

  }

  public string ConvertBetweenDataTableAndXML_AX(DataTable dtNeedCoveret)

  {

  SystemIOTextWriter tw = new SystemIOStringWriter();

  //if TableName is empty WriteXml() will throw Exception

  dtNeedCoveretTableName=dtNeedCoveretTableNameLength==?Table_AX:dtNeedCoveretTableName;

  dtNeedCoveretWriteXml(tw);

  dtNeedCoveretWriteXmlSchema(tw);

  return twToString();

  }

  public DataTable ConvertBetweenDataTableAndXML_AX(string xml)

  {

  SystemIOTextReader trDataTable = new SystemIOStringReader(xmlSubstring( xmlIndexOf(<?xml)));

  SystemIOTextReader trSchema = new SystemIOStringReader(xmlSubstring(xmlIndexOf(<?xml)));

  DataTable dtReturn = new DataTable();

  dtReturnReadXmlSchema(trSchema);

  dtReturnReadXml(trDataTable);

  return dtReturn;

  }


From:http://tw.wingwit.com/Article/program/net/201311/12556.html
    推薦文章
    Copyright © 2005-2022 電腦知識網 Computer Knowledge   All rights reserved.