随着时代的发展,我们要学的东西越来越多,这里我们就共同学习学习ADO.NET批注类型化数据集。ADO.NET批注使您能够在不修改基础架构的情况下修改类型化 DataSet 中元素的名称。如果修改基础架构中元素的名称,则会使类型化 DataSet 引用不存在于数据源中的对象,并且会丢失对存在于数据源中的对象的引用。
利用批注,您可以使用更有意义的名称来自定义类型化 DataSet 中对象的名称,从而使代码更易于阅读,类型化 DataSet 更易于为客户端使用,同时保持基础架构不变。例如,Northwind 数据库中 Customers 表的以下架构元素会生成 CustomersRow 这一 DataRow 对象名称和一个名为 Customers 的 DataRowCollection。
- <xs:element name="Customers">
- <xs:complexType>
- <xs:sequence>
- <xs:element name="CustomerID" type="xs:string" minOccurs="0" />
- </xs:sequence>
- </xs:complexType>
- </xs:element>
#T#DataRowCollection 名称 Customers 在客户端代码中是有意义的,但 DataRow 名称 CustomersRow 则会导致误解,因为它是单个对象。此外,在通常情况下,将不使用 Row 标识符来引用该对象,而仅将该对象当作 Customer 对象来引用。解决方案是为架构添加ADO.NET批注并标识 DataRow 和 DataRowCollection 对象的新名称。下面是上一架构的批注版本。
- <xs:element name="Customers" codegen:typedName="Customer" codegen:typedPlural="Customers">
- <xs:complexType>
- <xs:sequence>
- <xs:element name="CustomerID" type="xs:string" minOccurs="0" />
- </xs:sequence>
- </xs:complexType>
- </xs:element>
将 typedName 的值指定为 Customer 将生成 DataRow 对象名称 Customer。将 typedPlural 的值指定为 Customers 则会保留 DataRowCollection 名称 Customers。
若要使用类型化 DataSet 批注,则必须在 XML 架构定义语言 (XSD) 架构中包含以下 xmlns 引用。
- xmlns:codegen="urn:schemas-microsoft-com:xml-msprop"
下面是一个ADO.NET批注架构示例,它公开 Northwind 数据库的 Customers 表并包含与 Orders 表的关系。
- <?xml version="1.0" encoding="utf-8"?>
- <xs:schema id="CustomerDataSet"
- xmlns:codegen="urn:schemas-microsoft-com:xml-msprop"
- xmlns=""
- xmlns:xs="http://www.w3.org/2001/XMLSchema"
- xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
- <xs:element name="CustomerDataSet" msdata:IsDataSet="true">
- <xs:complexType>
- <xs:choice maxOccurs="unbounded">
- <xs:element name="Customers" codegen:typedName="Customer"
- codegen:typedPlural="Customers">
- <xs:complexType>
- <xs:sequence>
- <xs:element name="CustomerID"
- codegen:typedName="CustomerID" type="xs:string" minOccurs="0" />
- <xs:element name="CompanyName"
- codegen:typedName="CompanyName" type="xs:string" minOccurs="0" />
- <xs:element name="Phone" codegen:typedName="Phone"
- codegen:nullValue="" type="xs:string" minOccurs="0" />
- </xs:sequence>
- </xs:complexType>
- </xs:element>
- <xs:element name="Orders" codegen:typedName="Order"
- codegen:typedPlural="Orders">
- <xs:complexType>
- <xs:sequence>
- <xs:element name="OrderID" codegen:typedName="OrderID"
- type="xs:int" minOccurs="0" />
- <xs:element name="CustomerID"
- codegen:typedName="CustomerID"
- codegen:nullValue="" type="xs:string" minOccurs="0" />
- <xs:element name="EmployeeID"
- codegen:typedName="EmployeeID" codegen:nullValue="0"
- type="xs:int" minOccurs="0" />
- <xs:element name="OrderAdapter"
- codegen:typedName="OrderAdapter"
- codegen:nullValue="1980-01-01T00:00:00"
- type="xs:dateTime" minOccurs="0" />
- </xs:sequence>
- </xs:complexType>
- </xs:element>
- </xs:choice>
- </xs:complexType>
- <xs:unique name="Constraint1">
- <xs:selector xpath=".//Customers" />
- <xs:field xpath="CustomerID" />
- </xs:unique>
- <xs:keyref name="CustOrders" refer="Constraint1"
- codegen:typedParent="Customer" codegen:typedChildren="GetOrders">
- <xs:selector xpath=".//Orders" />
- <xs:field xpath="CustomerID" />
- </xs:keyref>
- </xs:element>
- </xs:schema>