揭秘ADO.NET批注在编程中的重大意义

开发 后端
利用ADO.NET批注,您可以使用更有意义的名称来自定义类型化 DataSet 中对象的名称,从而使代码更易于阅读,文章有详细的介绍。

随着时代的发展,我们要学的东西越来越多,这里我们就共同学习学习ADO.NET批注类型化数据集。ADO.NET批注使您能够在不修改基础架构的情况下修改类型化 DataSet 中元素的名称。如果修改基础架构中元素的名称,则会使类型化 DataSet 引用不存在于数据源中的对象,并且会丢失对存在于数据源中的对象的引用。

利用批注,您可以使用更有意义的名称来自定义类型化 DataSet 中对象的名称,从而使代码更易于阅读,类型化 DataSet 更易于为客户端使用,同时保持基础架构不变。例如,Northwind 数据库中 Customers 表的以下架构元素会生成 CustomersRow 这一 DataRow 对象名称和一个名为 Customers 的 DataRowCollection。

  1. <xs:element name="Customers"> 
  2. <xs:complexType> 
  3. <xs:sequence> 
  4. <xs:element name="CustomerID" type="xs:string" minOccurs="0" /> 
  5. </xs:sequence> 
  6. </xs:complexType> 
  7. </xs:element> 

#T#DataRowCollection 名称 Customers 在客户端代码中是有意义的,但 DataRow 名称 CustomersRow 则会导致误解,因为它是单个对象。此外,在通常情况下,将不使用 Row 标识符来引用该对象,而仅将该对象当作 Customer 对象来引用。解决方案是为架构添加ADO.NET批注并标识 DataRow 和 DataRowCollection 对象的新名称。下面是上一架构的批注版本。

  1. <xs:element name="Customers" codegen:typedName="Customer" codegen:typedPlural="Customers"> 
  2. <xs:complexType> 
  3. <xs:sequence> 
  4. <xs:element name="CustomerID" type="xs:string" minOccurs="0" /> 
  5. </xs:sequence> 
  6. </xs:complexType> 
  7. </xs:element> 

将 typedName 的值指定为 Customer 将生成 DataRow 对象名称 Customer。将 typedPlural 的值指定为 Customers 则会保留 DataRowCollection 名称 Customers。
若要使用类型化 DataSet 批注,则必须在 XML 架构定义语言 (XSD) 架构中包含以下 xmlns 引用。

  1. xmlns:codegen="urn:schemas-microsoft-com:xml-msprop" 

下面是一个ADO.NET批注架构示例,它公开 Northwind 数据库的 Customers 表并包含与 Orders 表的关系。

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <xs:schema id="CustomerDataSet"   
  3. xmlns:codegen="urn:schemas-microsoft-com:xml-msprop" 
  4. xmlns=""   
  5. xmlns:xs="http://www.w3.org/2001/XMLSchema"   
  6. xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> 
  7. <xs:element name="CustomerDataSet" msdata:IsDataSet="true"> 
  8. <xs:complexType> 
  9. <xs:choice maxOccurs="unbounded"> 
  10. <xs:element name="Customers" codegen:typedName="Customer" 
  11. codegen:typedPlural="Customers"> 
  12. <xs:complexType> 
  13. <xs:sequence> 
  14. <xs:element name="CustomerID" 
  15. codegen:typedName="CustomerID" type="xs:string" minOccurs="0" /> 
  16. <xs:element name="CompanyName" 
  17. codegen:typedName="CompanyName" type="xs:string" minOccurs="0" /> 
  18. <xs:element name="Phone" codegen:typedName="Phone" 
  19. codegen:nullValue="" type="xs:string" minOccurs="0" /> 
  20. </xs:sequence> 
  21. </xs:complexType> 
  22. </xs:element> 
  23. <xs:element name="Orders" codegen:typedName="Order" 
  24. codegen:typedPlural="Orders"> 
  25. <xs:complexType> 
  26. <xs:sequence> 
  27. <xs:element name="OrderID" codegen:typedName="OrderID" 
  28. type="xs:int" minOccurs="0" /> 
  29. <xs:element name="CustomerID" 
  30. codegen:typedName="CustomerID" 
  31.  codegen:nullValue="" type="xs:string" minOccurs="0" /> 
  32. <xs:element name="EmployeeID" 
  33. codegen:typedName="EmployeeID" codegen:nullValue="0"   
  34. type="xs:int" minOccurs="0" /> 
  35. <xs:element name="OrderAdapter" 
  36. codegen:typedName="OrderAdapter" 
  37. codegen:nullValue="1980-01-01T00:00:00"   
  38. type="xs:dateTime" minOccurs="0" /> 
  39. </xs:sequence> 
  40. </xs:complexType> 
  41. </xs:element> 
  42. </xs:choice> 
  43. </xs:complexType> 
  44. <xs:unique name="Constraint1"> 
  45. <xs:selector xpath=".//Customers" /> 
  46. <xs:field xpath="CustomerID" /> 
  47. </xs:unique> 
  48. <xs:keyref name="CustOrders" refer="Constraint1" 
  49. codegen:typedParent="Customer" codegen:typedChildren="GetOrders"> 
  50. <xs:selector xpath=".//Orders" /> 
  51. <xs:field xpath="CustomerID" /> 
  52. </xs:keyref> 
  53. </xs:element> 
  54. </xs:schema> 
责任编辑:田树 来源: 博客
相关推荐

2009-11-03 17:25:59

ADO.NET编程技巧

2009-11-03 16:37:10

2022-10-08 23:42:21

机器学习人工智能医疗健康

2009-10-29 10:34:31

ADO.NET使用技巧

2009-11-03 17:12:33

ADO.NET Exe

2009-11-04 13:51:46

ADO.NET性能

2009-11-04 10:23:05

ADO.NET Con

2009-11-04 15:55:49

ADO.NET VC

2009-11-11 10:55:10

ADO.NET对象

2009-11-04 16:31:40

ADO.NET Ora

2011-05-20 11:31:07

ADO.NET

2009-12-28 15:11:36

ADO.NET专家

2009-02-02 10:00:11

ADO.NETASP.NET

2011-06-02 09:39:29

ADO.NET

2009-12-23 10:10:59

ADO.NET编程

2010-01-04 11:02:06

ADO.NET组件

2009-09-14 13:37:25

LINQ ADO.NE

2010-01-04 10:48:30

ADO.NET特色

2009-07-06 10:43:51

ADO.NET

2009-12-30 15:55:20

ADO.NET数据库
点赞
收藏

51CTO技术栈公众号