(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。

(1)Create a DataTable          DataTable dt = new DataTable("Table_AX");

(2)Add columns for DataTable

dt.Columns.Add("column0", System.Type.GetType("System.String"));

DataColumn dc = new DataColumn("column1", System.Type.GetType("System.Boolean"));

dt.Columns.Add(dc); 
(3)Add rows for DataTable

DataRow dr = dt.NewRow();    //Initialize the row

dr["column0"] = "AX";

dr["column1"] = true;

dt.Rows.Add(dr);

(4)Select row

DataRow[] drs = dt.Select("column1 is null"); //Search the second row 如果没有赋值,则用is null来select

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

//Metod1          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. DataTable 转换成 Json的3种方法

    在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,A ...

  2. C#中将DataTable导出为HTML的方法

    今天我要向大家分享一种将DataTable导出为到HTML格式的方法.有时我们需要HTML格式的输出数据, 以下代码就可以帮助我们达到目的,. 首先,我们要绑定DataTable和 DataGridV ...

  3. DataTable转换成IList<T>的简单实现

    DataTable的无奈 很多时候,我们需要去操作DataTable.但DataTable的操作,实在是太不方便了.Linq?lambda表达式?统统没有... 特别是对现有结果集做进一步筛选,这样的 ...

  4. 自用的基于Emit的C#下DataTable转实体类方法

    之前一直在做WebForm的开发,数据绑定时直接DataTable绑定Gridview很方便,但是最近开始往MVC转,数据列表的传递和页面展示基本上是以List为主,像下面这样,遍历实体类的各个字段去 ...

  5. jquery dataTable汉化(插件形式)

    1.jquery dataTable.js 官网:http://datatables.net/ 中文:http://dt.thxopen.com/ 2.汉化提示信息(放到xx.js中,引入即可) 注: ...

  6. DataTable与DTO对象的简易转换类

    在web开发过程中,有时候为了数据传输的方便,比如:后台需要更新前端的ViewModel,此时我们定义一个与前端ViewModel结构一样的DTO对象,从数据层获取数据后,将数据封装成DTO然后序列化 ...

  7. asp.net DataTable导出Excel 自定义列名

    1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...

  8. asp.net dataTable转换成Json格式

    /// <summary> /// dataTable转换成Json格式 /// </summary> /// <param name="dt"> ...

  9. DataTable的orderby有关问题

    在网上找了一个在后台重新对DataTable排序的方法(之所以不在数据库是因为我生成的是报表,写了存储过程用的表变量,order by也要用变量,死活拼不起来,sql能力没过关,动态sql也试了) s ...

  10. 关于c#在DataTable中根据条件删除某一行

    我们经常会将数据源放在DataTable里面,但是有时候也需要移除不想要的行,下面的代码告诉你们 DataTable dts:                DataRow[] foundRow;   ...

随机推荐

  1. POJ 2286 The Rotation Game(IDA*)

    The Rotation Game Time Limit: 15000MS   Memory Limit: 150000K Total Submissions: 6396   Accepted: 21 ...

  2. 关于可图化序列的一点结论 NEU 1429

    Graphic Sequence A graphic sequence is a sequence of numbers which can be the degree sequence of som ...

  3. Error:Cannot find module 'stylus'

    在webpack 里面用了 stylus-loader,但npm instatll 没有正确安装,出现error: Cannot find module ‘stylus’. 解决办法: 重新npm i ...

  4. iOS-Cocoapods更新不及时

    一.问题 使用cocoapods搜索某些库时,搜索到的版本低于Github上面的版本,这样会导致一些问题.例如我在使用一个LTNavigationBar这个库时,在我升级到iOS10的时候,会导致导航 ...

  5. vue项目上传文件以及进度条

    最近做项目的时候,需要上传自定义镜像.并且附带进度条,上网查询一下资料,经过一番折磨,也总算做出来了,把自己写项目的内容给大家分享一下. 先直接贴代码吧 1.首先声明一个formData对象. 2.把 ...

  6. 解决当打开Unity时 提示项目已经打开,而自己之前并没有打开过(可能之前异常关闭)的问题

    当打开Unity时 提示项目已经打开,而自己之前并没有打开过(可能之前异常关闭) 发生这种情况时 打开项目目录中的 Temp文件夹,可以找到 一个 UnityLockfile 文件 将这个文件删除就可 ...

  7. CSS3 基本属性 浅析(含选择器、背景阴影、3D转换、动画等)

    1渐进增强原则 2私有前缀  不同浏览器在发布不同版本(一般测试版)时会加前缀,新增属性加上前缀进行支持测试:     Chrome浏览器:-webkit-border-radius: 5px;   ...

  8. L-Gap Substrings(uva 10829)

    题意:有一种形如uvu形式的字符串,其中u是非空字符串,且V的长度正好为L,那么称这个字符串为L-Gap字符串 给出一个字符串S,以及一个正整数L,问S中有多少个L-Gap子串. /* 这道题用到一个 ...

  9. 洛谷 P1262 间谍网络==Codevs 4093 EZ的间谍网络

    4093 EZ的间谍网络 时间限制: 10 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B ...

  10. 转一个网址,canvas用法

    http://blog.csdn.net/jia20003/article/details/9251893 http://www.w3school.com.cn/cssref/pr_animation ...