zoukankan      html  css  js  c++  java
  • DataSet与DataTable基本用法

    https://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

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

  • 相关阅读:
    【字符串/广搜】P1032 字串变换
    【动态规划】P1541 乌龟棋
    【动态规划/递归】(团队内部比赛试题)T134293 T2.货币系统问题
    Redis-事务
    Redis-Pipeline
    Redis-通过前缀获取所有key
    Spring 三级缓存
    TopK_LRU_归并

    如何从一亿个数组里找出最大的十个
  • 原文地址:https://www.cnblogs.com/monkeyZhong/p/4537938.html
Copyright © 2011-2022 走看看