你的位置:首页 > ASP.net教程

[ASP.net教程]DataSet与DataTable基本用法


http://files.cnblogs.com/files/monkeyZhong/DataSetExample.rar

 

在设计数据库操作或者

首先介绍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

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