揭秘ADO.NET批注在编程中的重大意义
创始人
2024-06-11 16:01:22
0

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

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

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

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

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

将 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.  version="1.0" encoding="utf-8"?> 
  2.  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.  name="CustomerDataSet" msdata:IsDataSet="true"> 
  8.  
  9.  maxOccurs="unbounded"> 
  10.  name="Customers" codegen:typedName="Customer" 
  11. codegen:typedPlural="Customers"> 
  12.  
  13.  
  14.  name="CustomerID" 
  15. codegen:typedName="CustomerID" type="xs:string" minOccurs="0" /> 
  16.  name="CompanyName" 
  17. codegen:typedName="CompanyName" type="xs:string" minOccurs="0" /> 
  18.  name="Phone" codegen:typedName="Phone" 
  19. codegen:nullValue="" type="xs:string" minOccurs="0" /> 
  20.  
  21.  
  22.  
  23.  name="Orders" codegen:typedName="Order" 
  24. codegen:typedPlural="Orders"> 
  25.  
  26.  
  27.  name="OrderID" codegen:typedName="OrderID" 
  28. type="xs:int" minOccurs="0" /> 
  29.  name="CustomerID" 
  30. codegen:typedName="CustomerID" 
  31.  codegen:nullValue="" type="xs:string" minOccurs="0" /> 
  32.  name="EmployeeID" 
  33. codegen:typedName="EmployeeID" codegen:nullValue="0"   
  34. type="xs:int" minOccurs="0" /> 
  35.  name="OrderAdapter" 
  36. codegen:typedName="OrderAdapter" 
  37. codegen:nullValue="1980-01-01T00:00:00"   
  38. type="xs:dateTime" minOccurs="0" /> 
  39.  
  40.  
  41.  
  42.  
  43.  
  44.  name="Constraint1"> 
  45.  xpath=".//Customers" /> 
  46.  xpath="CustomerID" /> 
  47.  
  48.  name="CustOrders" refer="Constraint1" 
  49. codegen:typedParent="Customer" codegen:typedChildren="GetOrders"> 
  50.  xpath=".//Orders" /> 
  51.  xpath="CustomerID" /> 
  52.  
  53.  
  54.  

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...