下面介绍ADO类的四种有关介绍和方法,将四个表关联在一起,并浏览这些关系。 如上例所示,CustomerID 使 Customers 表与 Orders 表相关联。 对于 Customers 表中的每个客户。
以返回特定客户的订单数以及他们的 由于 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 表中记录的子集,而不会生成运行时异常。 该扩展示例生成以下格式的输出。
- DataRelationcustomerOrdersRelation=
- customerOrders.Relations.Add("CustOrders",
- customerOrders.Tables["Customers"].Columns["CustomerID"],
- customerOrders.Tables["Orders"].Columns["CustomerID"]);
- DataRelationorderDetailRelation=
- customerOrders.Relations.Add("OrderDetail",
- customerOrders.Tables["Orders"].Columns["OrderID"],
- customerOrders.Tables["OrderDetails"].Columns["OrderID"],false);
- DataRelationorderProductRelation=
- customerOrders.Relations.Add("OrderProducts",
- customerOrders.Tables["Products"].Columns["ProductID"],
- customerOrders.Tables["OrderDetails"].Columns["ProductID"]);
- foreach(DataRowcustRowincustomerOrders.Tables["Customers"].Rows)
- {
- Console.WriteLine("CustomerID:"+custRow["CustomerID"]);
- foreach(DataRoworderRowincustRow.GetChildRows(customerOrdersRelation))
- {
- Console.WriteLine("OrderID:"+orderRow["OrderID"]);
- Console.WriteLine("\tOrderDate:"+orderRow["OrderDate"]);
- foreach(DataRowdetailRowinorderRow.GetChildRows(orderDetailRelation))
- {
- Console.WriteLine("\tProduct:"+
- detailRow.GetParentRow(orderProductRelation)["ProductName"]);
- Console.WriteLine("\tQuantity:"+detailRow["Quantity"]);
- }
- }
以上代码示例是一个扩展示例,ADO类在该示例中将返回 OrderDetails 表和 Products 表中的值,并只返回 Orders 表中记录的子集。