(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. [LOJ#2326]「清华集训 2017」简单数据结构

    [LOJ#2326]「清华集训 2017」简单数据结构 试题描述 参加完IOI2018之后就是姚班面试.而你,由于讨厌物理.并且想成为乔布斯一样的创业家,被成功踢回贵系. 转眼,时间的指针被指向201 ...

  2. 【SPOJ694】Distinct Substrings (SA)

    求不相同子串个数    该问题等价于求所有后缀间不相同前缀的个数..也就是对于每个后缀suffix(sa[i]),将贡献出n-sa[i]+1个,但同时,要减去那些重复的,即为height[i],故答案 ...

  3. windows系统——常用命令

    1.cleanmgr: 打开磁盘清理工具2.compmgmt.msc: 计算机管理3.conf: 启动系统配置实用程序4.charmap: 启动字符映射表5.calc: 启动计算器6.chkdsk.e ...

  4. css的fix高度缺失

    这个方法是百度百科手机页面用的,先为固定定位元素设一个父元素,不设高度,不设宽度,什么都不设,他的第一个子元素是我们需要做固定定位的元素,这个按照需求写好样式,此时,父元素的高度依然是0,如何使得父元 ...

  5. 在vue中使用sass

    首先安装node-sass和sass-loader cnpm install node-sass && sass-loader --save 在webpack.config.js 的m ...

  6. 遍历datalist中的checkbox,并获取此时的值

    原文发布时间为:2009-04-29 -- 来源于本人的百度文章 [由搬家工具导入] protected void Page_Load(object sender, EventArgs e) { if ...

  7. GC+JVM

    1.内存管理模型 ①以对象的方式管理内存,每个对象占据内存中连续的一段,分配在堆中.对象引用可以指向堆中的其他对象.非基本数据类型的对象等价于数据引用. ②基于栈和堆的内存管理都是动态分配,即在运行时 ...

  8. linux安全机制学习【转】

    转自:http://blog.csdn.net/qq_20307987/article/details/51307820 曾经一度想学来着,今天看到一个链接,讲的很好,算是写一下加深印象吧 1 栈溢出 ...

  9. 修复无法启动的mariadb

    一直在用的数据库,今天无论如何启动不了了,最后在archlinux wiki上查到了解决方法: mysql_install_db --user=mysql --basedir=/usr --datad ...

  10. reportlab包使用指南

    reportlab.canvas有这六个主要参数 1.pagesize:设置纸张大小    #from reportlab.lib.pagesizes import letter, A4  导入常见的 ...