使用ADO因为少数文件无法转换而无法加载工程,为此我也苦恼很久,后来终于让我找到了解决办法,而且还可以知道数据的分割位置。在我们平常的应用中,我们得到的结果可能是数组、集合或记录集的表现形式,我们该如何把它们转换成自描述的XML格式的数据呢?
从数据形式上看,XML是简单的纯字符串的文本格式,字符串在传递时是非常简单、快速而且是容易的,使用ADO数组在通过引用进行传递时有时是很慢的,而且处理起来很麻烦,而集合和记录集都是对象,在处理时会导致计算机性能的下降。
使用ADO并且这些对象都是与特定的平台相关联的,这就要求平台有内建的处理机制来处理对象的操作。使用ADO已经是W3C的标准,是平台无关的,我们的计算机的***要求就是能够处理简单的XML字符串,即XML解析器。#t#
它能够解析XML字符串,能够通过一种接口很容易地把数据分解成一个个独立的数据段,以便我们能够进行访问。XML解析器都很小,性能也很好,在每种平台上都可以找到。一旦我们接收到XML数据并把它解析成上面的例子的样式后。
我们就可以通过XSLT(eXstensible Stylesheet Language Transformations)把他们转换成不同的表现形式。使用ADO利用XML的数据格式进行数据传输,将会使我们编写应用程序代码的工作更简单轻松,而且具有良好的可伸缩性。
下面,我们就看看如何来转换我们的数据。我们的例子是在Microsoft Windows 2000,IIS5,MSXML3和ADO2.6下编写的,样例数据采用Microsoft SQL Server7.0自带的Northwind示例数据库。之所以采用SQL Server7而不采用支持XML的SQL Server使用ADO2000,是考虑到通用性的原则,我们的目的是:处理不同类型的数据源得到的记录集,而不仅仅是象SQL Server2000那样的支持XML输出的数据源。
使用ADO,是因为它形式多样,可以处理不同类型的数据源;使用XML,是因为它能够快速传输和解析。但本例的处理方法也适合在任何具有Micrsoft XML解析器,ADO2.5或以上版本的Windows,IIS,SQL Server的环境中。为简单起见,我们仅选择单价小于等于20美圆,库存大于等于20,产品名称小于等于6个字符的产品:
- <%
- Dim objRecordset
- Set objRecordset = Server.CreateObject("ADODB.Recordset")
- objRecordset.open _
- "SELECT ProductName, UnitPrice, UnitsInStock " _
- & "FROM Products " _
- & "WHERE UnitPrice <= 20 " _
- & "AND UnitsInStock >= 20 " _
- & "AND LEN(ProductName) <= 6 " _
- & "ORDER BY ProductName", _
- "Provider=SQLOLEDB;" _
- & "Data Source=SomeSQLServer;" _
- & "Initial Catalog=Northwind;" _
- & "User ID=MyUserName;" _
- & "Password=MyPassword;"
- %>
现在,我们就用3种方式把我们得到的记录集转换成XML格式。首先,使用ADO我们可以遍历整个记录集,采用XML DOM(Document Object Model),建立XML节点树: