C#中DataTable使用技巧
在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结。
一、DataTable简介
(1)构造函数
Ø DataTable()不带参数初始化DataTable类的新实例。
Ø DataTable(stringtableName)用指定的表名初始化DataTable类的新实例。
Ø DataTable(stringtableName,stringtableNamespace)用指定的表名和命名空间初始化DataTable类的新实例。
(2)常用属性
Ø CaseSensitive指示表中的字符串比较是否区分大小写。
Ø ChildRelations获取此DataTable的子关系的集合。
Ø Columns获取属于该表的列的集合。
Ø Constraints获取由该表维护的约束的集合。
Ø DataSet获取此表所属的DataSet。DataSet相关信息,可见我以前的一篇文章《数据访问(2)-DataSet》
Ø DefaultView获取可能包括筛选视图或游标位置的表的自定义视图。
Ø HasErrors获取一个值,该值指示该表所属的DataSet的任何表的任何行中是否有错误。
Ø MinimumCapacity获取或设置该表最初的起始大小。该表中行的最初起始大小。默认值为50。
Ø Rows获取属于该表的行的集合。
Ø TableName获取或设置DataTable的名称。
(3)常用方法
Ø AcceptChanges()提交自上次调用AcceptChanges()以来对该表进行的所有更改。
Ø BeginInit()开始初始化在窗体上使用或由另一个组件使用的DataTable。初始化发生在运行时。
Ø Clear()清除所有数据的DataTable。
Ø Clone()克隆DataTable的结构,包括所有DataTable架构和约束。
Ø EndInit()结束在窗体上使用或由另一个组件使用的DataTable的初始化。初始化发生在运行时。
Ø ImportRow(DataRowrow)将DataRow复制到DataTable中,保留任何属性设置以及初始值和当前值。
Ø Merge(DataTabletable)将指定的DataTable与当前的DataTable合并。
Ø NewRow()创建与该表具有相同架构的新DataRow。
二、DataTable使用技巧
(1)CreateaDataTable
DataTabledt=newDataTable("Table_AX");
(2)AddcolumnsforDataTable
//Method1
dt.Columns.Add("column0",System.Type.GetType("System.String"));
//Method2
DataColumndc=newDataColumn("column1",System.Type.GetType("System.Boolean"));
dt.Columns.Add(dc);
(3)AddrowsforDataTable
//Initializetherow
DataRowdr=dt.NewRow();
dr["column0"]="AX";
dr["column1"]=true;
dt.Rows.Add(dr);
//Doesn'tinitializetherow
DataRowdr1=dt.NewRow();
dt.Rows.Add(dr1);
(4)Selectrow
//Searchthesecondrow如果没有赋值,则用isnull来select
DataRow[]drs=dt.Select("column1isnull");
DataRow[]drss=dt.Select("column0='AX'");
(5)CopyDataTableincludedata
DataTabledtNew=dt.Copy();
(6)CopyDataTableonlyscheme
DataTabledtOnlyScheme=dt.Clone();
(7)Operateonerow
//对dt的操作
//Method1
DataRowdrOperate=dt.Rows[0];
drOperate["column0"]="AXzhz";
drOperate["column1"]=false;
//Method2
drOperate[0]="AXzhz";
drOperate[1]=false;
//Method3
dt.Rows[0]["column0"]="AXzhz";
dt.Rows[0]["column1"]=false;
//Method4
dt.Rows[0][0]="AXzhz";
dt.Rows[0][1]=false;
(8)EvaluateanotherDataTable'srowtocurrentDatatable
dtOnlyScheme.Rows.Add(dt.Rows[0].ItemArray);
(9)Converttostring
System.IO.StringWritersw=newSystem.IO.StringWriter();
System.Xml.XmlTextWriterxw=newSystem.Xml.XmlTextWriter(sw);
dt.WriteXml(xw);
strings=sw.ToString();
(10)FilterDataTable
dt.DefaultView.RowFilter="column1<>true";
dt.DefaultView.RowFilter="column1=true";
(11)Sortrow
dt.DefaultView.Sort="ID,NameASC";
dt=dt.DefaultView.ToTable();
(12)BindDataTable
//绑定的其实是DefaultView
gvTestDataTable.DataSource=dt;
gvTestDataTable.DataBind();
(13)judgetheDataTable’sColumnnameisastring
//判断一个字符串是否为DataTable的列名
dtInfo.Columns.Contains("AX");
(14)DataTableconverttoXMLandXMLconverttoDataTable
protectedvoidPage_Load(objectsender,EventArgse)
DataTabledt_AX=newDataTable();
//dt_AX.Columns.Add("Sex",typeof(System.Boolean));
//DataRowdr=dt_AX.NewRow();
//dr["Sex"]=true;
//dt_AX.Rows.Add(dr);
stringxml=ConvertBetweenDataTableAndXML_AX(dt_AX);
DataTabledt=ConvertBetweenDataTableAndXML_AX(xml);
}
publicstringConvertBetweenDataTableAndXML_AX(DataTabledtNeedCoveret)
{
System.IO.TextWritertw=newSystem.IO.StringWriter();
//ifTableNameisempty,WriteXml()willthrowException.
dtNeedCoveret.TableName=dtNeedCoveret.TableName.Length==0?"Table_AX":dtNeedCoveret.TableName;
dtNeedCoveret.WriteXml(tw);
dtNeedCoveret.WriteXmlSchema(tw);
returntw.ToString();
}
publicDataTableConvertBetweenDataTableAndXML_AX(stringxml)
{
System.IO.TextReadertrDataTable=newSystem.IO.StringReader(xml.Substring(0,xml.IndexOf("<?xml")));
System.IO.TextReadertrSchema=newSystem.IO.StringReader(xml.Substring(xml.IndexOf("<?xml")));
DataTabledtReturn=newDataTable();
dtReturn.ReadXmlSchema(trSchema);
dtReturn.ReadXml(trDataTable);
returndtReturn;
}
C#中DataTable使用技巧的更多相关文章
- DataTable使用技巧总结【转】
一.DataTable简介 ()构造函数 DataTable() 不带参数初始化DataTable 类的新实例. DataTable(string tableName) 用指定的表名初始化DataTa ...
- (转载)DataTable使用技巧总结
在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 一.Da ...
- C# 中 DataTable 使用详解。
在项目中经常用到DataTable,如果DataTable使用得当,不仅能使程序简洁实用,而且能够提高性能,达到事半功倍的效果,现对DataTable的使用技巧进行一下总结. 一.DataTable简 ...
- ios开发中的小技巧
在这里总结一些iOS开发中的小技巧,能大大方便我们的开发,持续更新. UITableView的Group样式下顶部空白处理 //分组列表头部空白处理 UIView *view = [[UIViewal ...
- C#中DataTable中的Compute方法使用收集
原文: C#中DataTable中的Compute方法使用收集 Compute函数的参数就两个:Expression,和Filter. Expresstion是计算表达式,关于Expression的详 ...
- 背水一战 Windows 10 (21) - 绑定: x:Bind 绑定, x:Bind 绑定之 x:Phase, 使用绑定过程中的一些技巧
[源码下载] 背水一战 Windows 10 (21) - 绑定: x:Bind 绑定, x:Bind 绑定之 x:Phase, 使用绑定过程中的一些技巧 作者:webabcd 介绍背水一战 Wind ...
- 绑定: x:Bind 绑定, x:Bind 绑定之 x:Phase, 使用绑定过程中的一些技巧
背水一战 Windows 10 之 绑定 x:Bind 绑定 x:Bind 绑定之 x:Phase 使用绑定过程中的一些技巧 示例1.演示 x:Bind 绑定的相关知识点Bind/BindDemo.x ...
- C#中DataTable排序、检索、合并等操作实例
转载引用至:http://www.jb51.net/article/49222.htm 一.排序1.获取DataTable的默认视图2.对视图设置排序表达式3.用排序后的视图导出的新DataT ...
- iOS开发中调试小技巧
对于软件开发而言,调试是必须学会的技能,重要性不言而喻.对于调试的技能,基本上是可以迁移的,也就是说你以前在其他平台上掌握的很多调试技巧,很多也是可以用在iOS开发中.不同语言.不同IDE.不同平台的 ...
随机推荐
- poj2996 模拟
Help Me with the Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3713 Accepted: ...
- 12 day 1
#include <cstdio> int i,j,m,n,t; long long f[6000][6000]; inline int min(int a,int b){ return ...
- (转载)【Android】ViewGroup全面分析
转载自:http://www.cnblogs.com/lqminn/archive/2013/01/23/2866543.html 一个Viewgroup基本的继承类格式如下: import andr ...
- 重新编译安装gcc-4.1.2(gcc版本降级)之TFS安装
wget http://gcc.parentingamerica.com/releases/gcc-4.1.2/gcc-4.1.2.tar.gz tar -zxfv gcc-4.1.2.tar.gz ...
- thinkcentre m8380t黑屏 解决办法
问题: 开机后,显示器上显示“无信号输入”,一直黑屏,但是主机的风扇.硬盘声音都正常. 解决办法: 把vga线等加紧了一些,屏幕还是不亮,然后我关掉插排电源,给cmos放了电,再重启就可以了. 这时需 ...
- 在Sharepoint 2010中启用Session功能的说明文档
在Sharepoint 2010中启用Session功能的说明文档 开发环境:Windows 7系统,SharePoint Server 2010,Visual Studio 2010 按以下步骤进行 ...
- Java读写文件的几种方式
自工作以后好久没有整理Java的基础知识了.趁有时间,整理一下Java文件操作的几种方式.无论哪种编程语言,文件读写操作时避免不了的一件事情,Java也不例外.Java读写文件一般是通过字节.字符和行 ...
- linux防止sshd被爆破(安装denyhosts)
这是一篇收集在日志里的文档,当初查看服务器sshd日志发现很多不明IP尝试登陆,因此想用什么办法阻止这样的事情发生.网上找了下用denyhosts可以解决这样的问题,因而也就将其收集在日志里了.由于时 ...
- MinGW/MSYS 交叉编译环境搭建
因为包的依赖关系不清楚,搭建时出错也不知道是什么原因,下面链接老外写的搭建步骤,写的非常详细还有脚本 已经编译的下载地址 http://ingar.satgnu.net/devenv/mingw32/ ...
- fork
#include <unistd.h> #include <stdlib.h> #include <stdio.h> #include <fcntl.h> ...