代码示例ADO.NET DataRelation使用

开发 后端
文章这里实例创建DataSet的Customers表和Orders表之间的ADO.NET DataRelation,并返回每个客户的所有订单,希望对大家有帮助。

ADO.NET还是比较常用的,于是我研究了一下ADO.NET DataRelation的使用,在这里拿出来和大家分享一下,希望对大家有用。ADO.NET DataRelation的一项主要功能就是在DataSet中从一个DataTable浏览到另一个。它使您能够在给定相关DataTable中的单个DataRow的情况下检索一个DataTable中的所有相关DataRow对象。例如,当建立客户表和订单表之间的ADO.NET DataRelation后,可以使用检索特定客户行的所有订单行。

以下代码示例创建DataSet的Customers表和Orders表之间的DataRelation,并返回每个客户的所有订单。

  1. DimcustomerOrdersRelationAsDataRelation=_ 
  2. customerOrders.Relations.Add("CustOrders",_  
  3. customerOrders.Tables("Customers").Columns("CustomerID"),_  
  4. customerOrders.Tables("Orders").Columns("CustomerID"))  
  5.  
  6. DimcustRow,orderRowAsDataRow  
  7.  
  8. ForEachcustRowIncustomerOrders.Tables("Customers").Rows  
  9. Console.WriteLine("CustomerID:"&custRow("CustomerID").ToString())  
  10.  
  11. ForEachorderRowIncustRow.GetChildRows(customerOrdersRelation)  
  12. Console.WriteLine(orderRow("OrderID").ToString())  
  13. Next  
  14. Next  

下一示例以上例为基础,将四个表关联在一起,并浏览这些关系。如上例所示,CustomerID使Customers表与Orders表相关联。对于Customers表中的每个客户,将确定Orders表中的所有子行,以返回特定客户的订单数以及他们的OrderID值。

#T#该扩展示例还将返回OrderDetails表和Products表中的值。Orders表使用OrderID与OrderDetails表相关联,以确定在每一客户订单中订购的产品及数量。由于OrderDetails表只包含已订购产品的ProductID,OrderDetails将使用ProductID与Products相关联,以返回ProductName。在这一关系中,Products表为父表,而OrderDetails表为子表。因此,当循环访问OrderDetails表时,将调用GetParentRow来检索相关的ProductName值。

请注意,当为Customers表和Orders表创建ADO.NET DataRelation时,没有为createConstraints标志指定任何值(默认为true)。它假定Orders表中的所有行都具有一个存在于父Customers表中的CustomerID值。如果CustomerID存在于Customers表之外的Orders表中,则ForeignKeyConstraint将引发异常。

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

责任编辑:田树 来源: 博客
相关推荐

2009-11-13 14:38:45

ADO.NET Dat

2009-11-12 13:53:27

ADO.NET Sel

2009-11-04 09:02:34

ADO.NET _C

2009-12-28 15:11:36

ADO.NET专家

2009-11-12 13:26:56

使用ADO.NET参数

2009-12-31 13:50:46

ADO.NET模型

2009-11-04 10:07:52

ADO.NET DbP

2009-10-29 10:34:31

ADO.NET使用技巧

2009-12-22 16:35:11

ADO.NET控件

2009-12-21 14:50:47

ADO.NET优化

2009-12-22 15:20:25

ADO.NET功能

2009-11-04 09:18:12

ADO.NET _Re

2009-12-21 16:53:06

ADO.NET使用说明

2009-08-21 16:35:08

使用C#结合ADO.N

2009-12-29 10:36:24

ADO.NET 工具

2009-11-12 10:15:37

ADO.NET使用

2009-12-21 11:29:13

Ado.Net代码

2009-12-22 09:36:29

ADO.NET代码

2009-11-03 15:47:10

ADO.NET数据异步

2011-05-20 11:31:07

ADO.NET
点赞
收藏

51CTO技术栈公众号