让我们一起学习ADO.NET XML架构

开发 后端
文章示例了ADO.NET XML架构和ADO.NET 应用程序中的 XSD.exe 传递的命名空间的语法,希望对大家有帮助。

学习ADO.NET时,你可能会遇到XML架构问题,这里将介绍解决方法,在这里拿出来和大家分享一下。如果给定符合ADO.NET XML架构定义语言 (XSD) 标准的ADO.NET XML架构,您就可以使用随 Windows 软件开发工具包 (SDK) 提供的 XSD.exe 工具生成强类型 DataSet。以下代码显示使用该工具生成 DataSet 的语法。

  1. xsd.exe /d /l:CS XSDSchemaFileName.xsd /eld /n:XSDSchema.Namespace 

#T#

在此语法中,/d 指令指示该工具生成 DataSet,/l: 告诉该工具要使用哪种语言(例如 C# 或 Visual Basic .NET)。 可选 /eld 指令指定您可以使用 LINQ to DataSet 对生成的 DataSet 进行查询。 当同时指定 /d 选项时可使用此选项。 有关更多信息,请参见查询类型化数据集。 可选的 /n: 指令指示该工具还要为名为 XSDSchema.Namespace 的 DataSet 生成命名空间。 命令的输出为 XSDSchemaFileName.cs,该输出可以在 ADO.NET 应用程序中编译和使用。 所生成的代码可以编译成库或模块。


以下代码显示访问向 ADO.NET 应用程序中的 XSD.exe 传递的命名空间的语法。

  1. Imports XSDSchema.Namespace 

以下代码示例使用名为 CustomerDataSet 的类型化 DataSet 来加载 Northwind 数据库中客户的列表。 当使用 Fill 方法加载数据后,该示例会使用类型化 CustomersRow (DataRow) 对象循环通过 Customers 表中的每个客户。 它提供了对 CustomerID 列的直接访问,而不是通过 DataColumnCollection 来访问。

  1. Dim customers As CustomerDataSetNew CustomerDataSet()  
  2. Dim adapter As SqlDataAdapter New SqlDataAdapter( _  
  3. "SELECT * FROM dbo.Customers;", _  
  4. "Data Source=(local);Integrated " & _  
  5. "Security=SSPI;Initial Catalog=Northwind")  
  6.  
  7. adapter.Fill(customers, "Customers")  
  8.  
  9. Dim customerRow As CustomerDataSet.CustomersRow  
  10. For Each customerRow In customers.Customers  
  11. Console.WriteLine(customerRow.CustomerID)  
  12. Next  


下面是用于该示例的ADO.NET XML架构。

  1. <?xml version="1.0" encoding="utf-8"?>   
  2. <xs:schema id="CustomerDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema"   
  3. xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> <xs:element name="CustomerDataSet"   
  4. msdata:IsDataSet="true"> <xs:complexType> <xs:choice   
  5. maxOccurs="unbounded"> <xs:element name="Customers">   
  6. <xs:complexType> <xs:sequence> <xs:element   
  7. name="CustomerID" type="xs:string" minOccurs="0" />   
  8. </xs:sequence> </xs:complexType>   
  9. </xs:element>   
  10. </xs:choice> </xs:complexType> </xs:element>   
  11. </xs:schema>  
责任编辑:田树 来源: 博客
相关推荐

2022-02-14 10:16:22

Axios接口HTTP

2022-03-31 18:59:43

数据库InnoDBMySQL

2021-08-27 07:06:10

IOJava抽象

2021-12-29 08:27:05

ByteBuffer磁盘服务器

2022-03-08 17:52:58

TCP格式IP

2021-03-18 00:04:13

C# 类型数据

2021-11-26 07:00:05

反转整数数字

2021-07-15 07:23:28

Singlefligh设计

2022-02-14 07:03:31

网站安全MFA

2016-09-06 10:39:30

Dell Techno

2022-06-26 09:40:55

Django框架服务

2021-07-14 08:00:12

Numa架构Linux

2021-05-31 09:23:04

管道模式责任链

2023-08-14 08:38:26

反射reflect结构体

2023-08-02 08:35:54

文件操作数据源

2022-07-10 23:15:46

Go语言内存

2022-08-01 07:57:03

数组操作内存

2021-07-31 11:40:55

Openresty开源

2012-04-14 20:47:45

Android

2021-12-16 12:01:21

区块链Libra货币
点赞
收藏

51CTO技术栈公众号