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
         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;
        }
DataTable的一些特殊用法:Select
当你从数据库里取出一些数据,然后要对数据进行整合,你很容易就会想到:
复制代码
1DataTable dt = new DataTable();//假设dt是由"SELECT C1,C2,C3 FROM T1"查询出来的结果
2for (int i = 0; i < dt.Rows.Count; i++)
3{
4    if (dt.Rows[i]["C1"].ToString() == "abc")//查询条件
5    {
6        //进行操作
7    }
8}
复制代码
但这种做法用一两次还好说,用多了就累了。那有没有更好的方法呢?记得LinQ是可以直接对DataTable进行查询操作的,那在.Net Framework 2.0里,有没有类似的方法呢?答案是肯定的,就是dt.Select(),上面的操作可以改成这样:
1DataRow[] drArr = dt.Select("C1=‘abc‘");//查询
还可以这样操作:
1DataRow[] drArr = dt.Select("C1 LIKE ‘abc%‘");//模糊查询
2DataRow[] drArr = dt.Select("‘abc‘ LIKE C1 + ‘%‘", "C2 DESC");//另一种模糊查询的方法
3DataRow[] drArr = dt.Select("C1=‘abc‘", "C2 DESC");//排序
问题又来了,如果要把DataRow赋值给新的DataTable,怎么赋值呢?你可能会想到:
1DataTable dtNew = dt.Clone();
2for (int i = 0; i < drArr.Length; i++)
3{
4    dtNew.Rows.Add(drArr[i]);
5}
但这样程序就会出错,说该DataRow是属于其他DataTable的,那要怎么做呢?很简单,这样就可以解决了:
1DataTable dtNew = dt.Clone();
2for (int i = 0; i < drArr.Length; i++)
3{
4    dtNew.ImportRow(drArr[i]);
5}
这样就完成了。
/*
* 还可以利用DataView来达到检索的目的。
*/
DataTable dataSource = new DataTable();
DataView dv = dataSource.DefaultView;
dv.RowFilter = "columnA = ‘abc‘";
//1.过滤后直接获取DataTable
DataTable newTable1 = dv.ToTable();
//2.设置新DataTable的TableName
DataTable newTable2 = dv.ToTable("NewTableName");
//3.设置新表是否过滤重复项,拥有的列的列名以及出现的顺序
//即可以设置新表的字段。但是字段名肯定是老表dataSource中拥有的。
DataTable newTable3 =
dv.ToTable(true, new string[] { "columnA,columnF,columnC" });
//4.综合了2.3两点。
DataTable newTable4 =
dv.ToTable("NewTableName", true, new string[] { "columnA,columnF,columnC" });
时间: 2024-10-31 09:50:13

DataTable 类的相关文章

DataTable类

DataTable是一个使用非常多的类,记得我在刚刚开始学习.Net的时候就已经了解并用过这个类,但如今再来看看,才发现这个类非常之复杂,复杂表现在哪些地方呢?主要是这个类与其他很多类都有关联,也就是说,你要玩透DataTable这个类,你必须要了解很多其他的类. DataTable是一个很古老的类,再往前不清楚,但是.Net2.0就肯定有了.主要用于数据的封装与存储等等.这个类,你要是在公司里工作,必定会用到,无论是维护旧系统或是使用一些老框架都会用到,必须要熟悉常用的操作. 下面给出一些Da

C#操作DataTable类

一.DataTable简介 (1)构造函数 DataTable()  不带参数初始化DataTable 类的新实例 DataTable(string tableName) 用指定的表名初始化DataTable 类的新实例 DataTable(string tableName, string tableNamespace)  用指定的表名和命名空间初始化DataTable类的新实例 (2)常用属性 CaseSensitive 指示表中的字符串比较是否区分大小写 ChildRelations 获取此

【WinForm】杂记(6):C#之DataTable类(总结)

内容列表 属性 获取行列数 方法 添加列 添加行 删除行列 获取列名 获取列类型 更改列名 获取单元格数值 写入数值到单元格 其它 转置 将一张表的某列添加到另一张表 将一张表的某行添加到另一张表 属性 获取行列数 int numOfRows = dt.Rows.Count; int numOfCols = dt.Columns.Count; 方法 添加列 dt.Columns.Add("Name", typeof(string)).SetOrdinal(0);//to the fir

深入详解DataTable

在学习DataTable知识之前,我们有必要了解下ADO.NET.以下摘自MSDN: ADO.NET 对 Microsoft SQL Server 和 XML 等数据源以及通过 OLE DB 和 XML 公开的数据源提供一致的访问.数据共享使用者应用程序可以使用 ADO.NET 来连接到这些数据源,并检索.处理和更新所包含的数据.ADO.NET 通过数据处理将数据访问分解为多个可以单独使用或一前一后使用的不连续组件.ADO.NET 包含用于连接到数据库.执行命令和检索结果的 .NET Frame

C# DataTable的詳細用法

转载别人的转载,原作者都不知道了 在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 一.DataTable简介 (1)构造函数           DataTable()   不带参数初始化DataTable 类的新实例.           DataTable(string tableName)  用指定的表名初始化DataTable 类的新实例.           

C# DataTable详细用法

通过经常使用的项目中的DataTable,假设DataTable使用得当.不仅能使程序简洁有用.并且可以提高性能,达到事半功倍的效果.现对DataTable的使用技巧进行一下总结. 一.DataTable简单介绍 (1)构造函数 DataTable()   不带參数初始化DataTable 类的新实例. DataTable(string tableName)  用指定的表名初始化DataTable 类的新实例. DataTable(string tableName, string tableNa

C# DataSet与DataTable的区别和用法

DataSet是数据集,DataTable是数据表,DataSet存储多个DataTable.DataSet和DataTable像是专门存储数据的一个容器,在你查询数据库得到一些结果时可以存在里面. DataSet功能强大有浏览.排序.搜索.过滤.处理分级数据.缓存更改等功能,还可以与XML数据互换.DataSet中可包括多个DataTable,可将多个查询结构存到一个DataSet中,方便操作 ADO.NET开发人员为方便数据处理开发出来的,是数据的集合,为解决DataReader的缺陷设计的

C# DataTable的详细用法[转]

原文链接 1.新建表   private DataTable vsDt =new DataTable(); 2.清空表中内容(表中的列还在)  vsDt.Clear(); 3.清空表中的列   vsDt.Columns.Clear(); 4.表中添加列 vsDt.Columns.Add("BH", typeof(string)); vsDt.Columns.Add("RQ", typeof(string)); 5.表中添加空行 DataRow vsDr = vsDt

jquery datatable 常用例子

在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 一.DataTable简介 (1)构造函数           DataTable()   不带参数初始化DataTable 类的新实例.           DataTable(string tableName)  用指定的表名初始化DataTable 类的新实例.           DataTable(string