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" });