通过经常使用的项目中的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

          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("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;

        }

C# DataTable详细用法的更多相关文章

  1. heckboxlist详细用法、checkboxlist用法、checkboxlist

    heckboxlist详细用法.checkboxlist用法.checkboxlist for (int i = 0; i < CheckBoxList1.Items.Count; i++) { ...

  2. C#播放声音的四种方法 +AxWindowsMediaPlayer的详细用法

    C#播放声音的四种方法 第一种是利用DirectX 1.安装了DirectX SDK(有9个DLL文件).这里我们只用到MicroSoft.DirectX.dll和 Microsoft.Directx ...

  3. DataTable.Compute()用法

    DataTable.Compute()用法 2010-04-07 11:28 一.DataTable.Compute()方法說明如下 作用:          计算用来传递筛选条件的当前行上的给定表达 ...

  4. 在DOS下的DEBUG命令的详细用法

    在DOS下的DEBUG命令的详细用法 名称 解释 格式 a (Assemble) 逐行汇编 a [address] c (Compare) 比较两内存块 c range address d (Dump ...

  5. __declspec关键字详细用法

    __declspec关键字详细用法 __declspec用于指定所给定类型的实例的与Microsoft相关的存储方式.其它的有关存储方式的修饰符如static与extern等是C和C++语言的ANSI ...

  6. CString.Format的详细用法(转)

    CString.Format的详细用法(转) 在MFC程序中,使用CString来处理字符串是一个很不错的选择.CString既可以处理Unicode标准的字符串,也可以处理ANSI标准的字符串.CS ...

  7. IFRAM的详细用法

    IFRAM的详细用法:   IFRAM的详细用法:  <IFRAME>用于设置文本或图形的浮动图文框或容器. BORDER <IFRAME BORDER="3"& ...

  8. 【转】java.util.vector中的vector的详细用法

    [转]java.util.vector中的vector的详细用法 ArrayList会比Vector快,他是非同步的,如果设计涉及到多线程,还是用Vector比较好一些 import java.uti ...

  9. DOM Style样式对象的详细用法

    DOM Style样式对象的详细用法 HTML Style样式比较复杂,相应访问.修改方法也有所差异.参考相关资料,整理如下. 典型Html文件如下,有三种定义方式. <head>     ...

随机推荐

  1. Windows下visual studio code搭建golang开发环境

    Windows下visual studio code搭建golang开发环境 序幕 其实环境搭建没什么难的,但是遇到一些问题,主要是有些网站资源访问不了(如:golang.org),导致一些包无法安装 ...

  2. SVNKIT操作SVN版本库的完整例子

    Model: package com.wjy.model; public class RepositoryInfo { public static String storeUrl="http ...

  3. 重构后的ConditionHelper

    两三个月前曾写过<重构ConditionHelper>的随笔,但不知是因为写得不够好还是没有什么新意,我发表至博客园首页时被屏蔽了,本着好的知识应该分享给更多人,加之新项目已交付用户使用所 ...

  4. VS上的WebService入门贴

    由于项目需要,最近要熟悉一下通过IIS发布WebService.首先熟悉一下使用VS来创建webservice并且调用它. //------------------------------------ ...

  5. Swift的属性,方法,下标脚本以及继承

    从这篇章节起,Swift编程语言指南大部分的重要内容在于概念,代码并非太多.理解Swift的面向对象理念,语法以及类结构,构造析构过程对于非常好的应用Swift语言将会有比較大的帮助. 属性 存储属性 ...

  6. git笔记之解决eclipse不能提交jar等文件的问题

    今天用git托管了一个java web项目,由于是web项目,所以要上传jar文件(此项目未使用maven管理),一直使用git commit and push,就是在server上看不到jar文件上 ...

  7. 二叉树的建立与遍历(山东理工OJ)

    题目描写叙述 已知一个按先序序列输入的字符序列,如abc,,de,g,,f,,,(当中逗号表示空节点).请建立二叉树并按中序和后序方式遍历二叉树,最后求出叶子节点个数和二叉树深度. 输入 输入一个长度 ...

  8. Android onTouch、OnLongClick、onClick和ScrollView滑动事件冲突

    为了实现近期录制的长按,松开手指,结束录制功能.在项目,难道你去走一走会头晕,书写demo为了下一个梳理. 顺便研究android事件调用机制. 先上效果界面: 布局: <RelativeLay ...

  9. php获胜的算法的概率,它可用于刮,大转盘等彩票的算法

    php获胜的算法的概率,它可用于刮,大转盘等彩票的算法. easy,代码里有具体凝视说明.一看就懂 <?php /* * 经典的概率算法, * $proArr是一个预先设置的数组. * 假设数组 ...

  10. Visual Studio跨平台开发实战(3) - Xamarin iOS多页面应用程式开发

    原文 Visual Studio跨平台开发实战(3) - Xamarin iOS多页面应用程式开发 前言 在前一篇教学中, 我们学会如何使用Visual Studio 搭配Xcode 进行iOS基本控 ...