这篇文章主要介绍“ADO类的原理和作用是什么”,在日常操作中,相信很多人在ADO类的原理和作用是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ADO类的原理和作用是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
下面介绍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"]); foreachDataRowcustRowincustomerOrders.Tables["Customers"].Rows) { Console.WriteLine"CustomerID:"+custRow["CustomerID"]); foreachDataRoworderRowincustRow.GetChildRowscustomerOrdersRelation)) { Console.WriteLine"OrderID:"+orderRow["OrderID"]); Console.WriteLine"\tOrderDate:"+orderRow["OrderDate"]); foreachDataRowdetailRowinorderRow.GetChildRowsorderDetailRelation)) { Console.WriteLine"\tProduct:"+ detailRow.GetParentRoworderProductRelation)["ProductName"]); Console.WriteLine"\tQuantity:"+detailRow["Quantity"]); } }
以上代码示例是一个扩展示例,ADO类在该示例中将返回 OrderDetails 表和 Products 表中的值,并只返回 Orders 表中记录的子集。