程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> DataSet與DataTable基本用法,datasetdatatable

DataSet與DataTable基本用法,datasetdatatable

編輯:C#入門知識

DataSet與DataTable基本用法,datasetdatatable


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

子行可以有很多,但是父行只有一行。
至於那些外鍵,主鍵,約束,以及更新表的時候的一些操作,因為涉及到數據庫的很多知識,這裡就不做描述了,我們側重這兩個類的用法。

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved