DataSet与DataTable基本用法

王朝学院·作者佚名  2016-05-20
窄屏简体版  字體: |||超大  

DataSet与DataTable基本用法http://files.cnblogs.com/files/monkeyZhong/DataSetExample.rar

在设计数据库操作或者xml操作等表格数据时,我们难免要跟DataSet和DataTable打交道,我们这里就介绍下这几个类的用法:

首先介绍DataTable,其实就是一个二维表格,没那么悬乎,举个构造的例子:

DataTable dt = new DataTable("Customers"); dt.Columns.Add("CustomerID", typeof(Int32)); dt.Columns.Add("CustomerName", typeof(String)); dt.Columns.Add("Description", typeof(string)); DataRow row = dt.NewRow(); row[0] = 001; row[1] = "大众"; row[2] = "中档车"; dt.Rows.Add(row); DataRow row2 = dt.NewRow(); row2[0] = 002; row2[1] = "奔驰"; row2[2] = "豪车"; dt.Rows.Add(row2);

这就构造了一个二行三列的二维表了。

其次就是DataSet:我们可以把它看做是DataTable的集合容器,我们可以往里面添加很多表。比如:

1 customerOrders = new DataSet();2 customerOrders.Tables.Add(customerTable);3 customerOrders.Tables.Add(orderTable);4 customerOrders.Tables.Add(orderDetailTable);5 customerOrders.Tables.Add(PRoductTable);

View Code这里就添加了四个表。

当然,DataSet还有其他的内容,这里我平时用得少但是很重要的地方就是DataRelation,这个我们可以想成表与表之间通过某列来建立一个联系,这样我们就可以通过某行的GetChildRows得到子列的行集合(满足关系),或者通过GetParentRow得到父列的行。

1 DataRelation customerOrdersRelation = new DataRelation("CustOrders", 2 customerOrders.Tables["Customers"].Columns["CustomerID"], 3 customerOrders.Tables["Orders"].Columns["CustomerID"]); 4 customerOrders.Relations.Add(customerOrdersRelation); 5 DataRelation orderDetailRelation = customerOrders.Relations.Add("OrderDetail", 6 customerOrders.Tables["Orders"].Columns["OrderID"], 7 customerOrders.Tables["OrderDetails"].Columns["OrderID"], false); 8 DataRelation orderProductRelation = customerOrders.Relations.Add("OrderProducts", 9 customerOrders.Tables["Product"].Columns["ProductID"],10 customerOrders.Tables["OrderDetails"].Columns["ProductID"]);11 12 DataRow[] rows = customerOrders.Tables["Customers"].Rows[0].GetChildRows(customerOrdersRelation);13 DataTable dt = orderTable.Clone();14 foreach (DataRow row in rows)15 {16 dt.ImportRow(row);17 18 }19 20 StringBuilder sw = new StringBuilder();21 foreach (DataRow custRow in customerOrders.Tables["Customers"].Rows)22 {23 sw.AppendLine("Customer ID:" + custRow["CustomerID"]);24 foreach (DataRow orderRow in custRow.GetChildRows(customerOrdersRelation))25 {26 sw.AppendLine(" Order ID:" + orderRow["OrderID"]);27 sw.AppendLine("\tOrder Date:" + orderRow["DateTime"]);28 foreach (DataRow detailRow in orderRow.GetChildRows(orderDetailRelation))29 {30 sw.AppendLine("\tProduct" + detailRow.GetParentRow(orderProductRelation)["ProductName"]);31 }32 }33 }

View Code子行可以有很多,但是父行只有一行。至于那些外键,主键,约束,以及更新表的时候的一些操作,因为涉及到数据库的很多知识,这里就不做描述了,我们侧重这两个类的用法。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航