作者对于ADO类理解与看法

下面介绍ADO类的四种有关介绍和方法,将四个表关联在一起,并浏览这些关系。 如上例所示,CustomerID 使 Customers 表与 Orders 表相关联。 对于 Customers 表中的每个客户。

成都创新互联是一家专业提供鲅鱼圈企业网站建设,专注与成都网站制作、网站设计、外贸网站建设H5高端网站建设、小程序制作等业务。10年已为鲅鱼圈众多企业、政府机构等服务。创新互联专业网站建设公司优惠进行中。

以返回特定客户的订单数以及他们的 由于 OrderDetails 表只包含已订购产品的 ProductID,OrderDetails 将使用 ProductID 与 Products 相关联,以返回 ProductName。 在这一关系中,Products 表为父表,而 Order Details 表为子表。 因此,当循环访问 OrderDetails 表时,将调用 GetParentRow 来检索相关的 ProductName 值。请注意,当为 Customers 表和 Orders 表创建 DataRelation 时,ADO类没有为 createConstraints 标志指定任何值(默认为 true)。

它假定 Orders 表中的所有行都具有一个存在于父 Customers 表中的 CustomerID 值。 如果 CustomerID 存在于 Customers 表之外的 Orders 表中,则 ForeignKeyConstraint 将引发异常。如果子列可能包含父列不包含的值,添加 DataRelation 时请将 createConstraints 标志设置为 false。 在该示例中,ADO类对于 Orders 表和 OrderDetails 表之间的 DataRelation,createConstraints 标志将设置为 false。 这样,应用程序就可以返回 OrderDetails 表中的所有记录并只返回 Orders 表中记录的子集,而不会生成运行时异常。 该扩展示例生成以下格式的输出。

 
 
  1. DataRelationcustomerOrdersRelation=
  2. customerOrders.Relations.Add("CustOrders",
  3. customerOrders.Tables["Customers"].Columns["CustomerID"],
  4. customerOrders.Tables["Orders"].Columns["CustomerID"]);
  5. DataRelationorderDetailRelation=
  6. customerOrders.Relations.Add("OrderDetail",
  7. customerOrders.Tables["Orders"].Columns["OrderID"],
  8. customerOrders.Tables["OrderDetails"].Columns["OrderID"],false);
  9. DataRelationorderProductRelation=
  10. customerOrders.Relations.Add("OrderProducts",
  11. customerOrders.Tables["Products"].Columns["ProductID"],
  12. customerOrders.Tables["OrderDetails"].Columns["ProductID"]);
  13. foreach(DataRowcustRowincustomerOrders.Tables["Customers"].Rows)
  14. {
  15. Console.WriteLine("CustomerID:"+custRow["CustomerID"]);
  16. foreach(DataRoworderRowincustRow.GetChildRows(customerOrdersRelation))
  17. {
  18. Console.WriteLine("OrderID:"+orderRow["OrderID"]);
  19. Console.WriteLine("\tOrderDate:"+orderRow["OrderDate"]);
  20. foreach(DataRowdetailRowinorderRow.GetChildRows(orderDetailRelation))
  21. {
  22. Console.WriteLine("\tProduct:"+
  23. detailRow.GetParentRow(orderProductRelation)["ProductName"]);
  24. Console.WriteLine("\tQuantity:"+detailRow["Quantity"]);
  25. }
  26. }

以上代码示例是一个扩展示例,ADO类在该示例中将返回 OrderDetails 表和 Products 表中的值,并只返回 Orders 表中记录的子集。

本文名称:作者对于ADO类理解与看法
文章URL:http://www.zyruijie.cn/qtweb/news26/1426.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联