(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 2976 Dropping tests(01分数规划入门)

    Dropping tests Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11367   Accepted: 3962 D ...

  2. 关于jena-fuseki SPARQL query版本问题的解决方案

    在做“Apache jena SPARQL endpoint及推理”时,遇到了不少问题,主要原因是jena-fuseki版本更新了.以下对问题解决方案做下笔记.想了解更多,请查阅底部参考文献. Que ...

  3. 3984: 玩具(toy)

    3984: 玩具(toy) 题目描述 这个故事发生在很久以前,在 IcePrincess_1968 和 IcePrince_1968 都还在上幼儿园的时候. IcePrince_1968 最近迷上了一 ...

  4. JavaScript 笔记(1) -- 基础 & 函数 & 循环 & ...

    目录(代码编写): 显示数据 语法 变量 & 变量类型 对象 函数 事件 字符串 运算符 条件语句 循环语句 Break 和 Continue 使用 JS 近两年,现整理下一些基本: HTML ...

  5. 【BZOJ4300】绝世好题(二进制,DP)

    题意: n<=100000,ai<=2*10^9 思路:按二进制逐位考虑,只要有至少1位取and后为1就可以接下去 设dp[i]为第i位取and之后为1的最长的序列长度,意会一下 #inc ...

  6. A way to CQRS and DDD

    Recently, I'm trying to make a approach to DDD with CQRS, Event Sourcing, Domain Isolation, Domain R ...

  7. H5 <audio> 音频标签自定义样式修改以及添加播放控制事件

    H5 <audio> 音频标签自定义样式修改以及添加播放控制事件 Dandelion_drq 关注 2017.08.28 14:48* 字数 331 阅读 2902评论 3喜欢 3 说明: ...

  8. hdu 4857(好题,反向拓扑排序)

    逃生 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submissi ...

  9. OSX 系统无法直接用 Chrome 双击点击打开本地 html 文件

    在 Mac OS X 下,文件经常会被附加上 OS X 特有的扩展属性 ( extend attributes ),具体表现是用 ls -l 查看时会有 @ 的标记,譬如: $ ls -l index ...

  10. Cryptography I 学习笔记 --- 零碎

    1. KDF(密钥推导函数,key derivation function),根据用户输入的一个初始密钥来生成一系列的后续密钥.可以使用PRF来生成 2. 可以用salt与slow hash func ...