由于XML(可扩展标记语言:eXtensible Markup Language)真正的平台无关性,它正在逐渐成为数据传输的主要介质。XML是一种自描述的语言,数据本身就已经包含了元数据,即关于数据本身的信息。例如:“孟子E章1757281793923net_lover1807581793923”这组数据,从字面很难看出它代表什么意思,也不清楚它有几个数据段组成,但是,如果用XML来做如下的描述,我们就可以清楚地看到每个数据段所代表的含义:
<PersonData>
<Person>
<姓名>孟子E章</姓名>
<身高>175</身高>
<体重>72</体重>
<电话>81793923</电话>
</Person>
<Person>
<姓名>net_lover</姓名>
<身高>180</身高>
<体重>75</体重>
<电话>81793923</电话>
</Person>
</PersonData>
从上面的一段XML中,我们不但可以清楚地看到每一个数据代表的是什么意思了,而且还可以知道数据的分割位置。在我们平常的应用中,我们得到的结果可能是数组、集合或记录集的表现形式,我们该如何把它们转换成自描述的XML格式的数据呢?从数据形式上看,XML是简单的纯字符串的文本格式,字符串在传递时是非常简单、快速而且是容易的,数组在通过引用进行传递时有时是很慢的,而且处理起来很麻烦,而集合和记录集都是对象,在处理时会导致计算机性能的下降,并且这些对象都是与特定的平台相关联的,这就要求平台有内建的处理机制来处理对象的操作。XML已经是W3C的标准,是平台无关的,我们的计算机的唯一要求就是能够处理简单的XML字符串,即XML解析器,它能够解析XML字符串,能够通过一种接口很容易地把数据分解成一个个独立的数据段,以便我们能够进行访问。XML解析器都很小,性能也很好,在每种平台上都可以找到。一旦我们接收到XML数据并把它解析成上面的例子的样式后,我们就可以通过XSLT(eXstensible Stylesheet Language Transformations)把他们转换成不同的表现形式。利用XML的数据格式进行数据传输,将会使我们编写应用程序代码的工作更简单轻松,而且具有良好的可伸缩性。
下面,我们就看看如何来转换我们的数据。我们的例子是在Microsoft Windows 2000,IIS5,MSXML3和ADO2.6下编写的,样例数据采用Microsoft SQL Server7.0自带的Northwind示例数据库。之所以采用SQL Server7而不采用支持XML的SQL Server2000,是考虑到通用性的原则,我们的目的是:处理不同类型的数据源得到的记录集,而不仅仅是象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格式。首先,我们可以遍历整个记录集,采用XML DOM(Document Object Model),建立XML节点树:
<%
Dim objXMLDOM, objRootNode, objNode
Set objXMLDOM = Server.CreateObject("MSXML2.DOMDocument")
Set objRootNode = objXMLDOM.createElement("xml")
objXMLDOM.documentElement = objRootNode
Do While NOT objRecordset.EOF
Set objRowNode = objXMLDOM.createElement("row")
Set objNode = objXMLDOM.createElement("ProductName")
objNode.text = objRecordset.Fields.Item("ProductName").Value
objRowNode.appendChild(objNode)
Set objNode = objXMLDOM.createElement("UnitPrice")
objNode.text = objRecordset.Fields.Item("UnitPrice").Value
objRowNode.appendChild(objNode)
Set objNode = objXMLDOM.createElement("UnitsInStock")
objNode.text = objRecordset.Fields.Item("UnitsInStock").Value
objRowNode.appendChild(objNode)
objRootNode.appendChild(objRowNode)
objRecordset.MoveNext
Loop
Set objNode = Nothing
Set objRowNode = Nothing
Set objRootNode = Nothing
Set objRecordset = Nothing
%>
现在,我们就得到了一个XML DOM对象。这种方法对于记录集很大时性能并不理想,因为系统内存中要同时保存ADO记录集对象和XML DOM对象。
第二个办法,遍历记录集,直接生成XML字符串本身:
<%
Dim strXML
strXML = "<xml>"
objRecordset.MoveFirst
Do While NOT objRecordset.EOF
strXML = strXML & "<row>"
strXML = strXML & "<ProductName>" _
& objRecordset.Fields.Item("ProductName").Value _
& "</ProductName>"
strXML = strXML & "<UnitPrice>" _
& objRecordset.Fields.Item("UnitPrice").Value _
& "</UnitPrice>"
strXML = strXML & "<UnitsInStock>" _
& objRecordset.Fields.Item("UnitsInStock").Value _
& "</UnitsInStock>"
strXML = strXML & "</row>"
objRecordset.MoveNext
Loop
strXML = strXML & "</xml>"
Set objRecordset = Nothing
%>
但是,以上两种方法最大的缺陷是不能够重用代码,我们把节点的名字都写死了,如果我们进行不同字段的查询,我们还必须手动更改我们的代码,以满足不同节点的需要。我们下面的方法将变得更加通用。
第三种方法:可重用的方法。
<%
Dim strXML
strXML = "<xml>"
objRecordset.MoveFirst
Do While NOT objRecordset.EOF
strXML = strXML & "<row>"
For Each varItem In objRecordset.Fields
strXML = strXML _
& "<" & varItem.name & ">" _
& varItem.value _
& "</" & varItem.name & ">"
Next
strXML = strXML & "</row>"
objRecordset.MoveNext
Loop
strXML = strXML & "</xml>"
Set objRecordset = Nothing
%>
相关推荐
### 利用XSLT将ADO记录集转换为XML #### 概述 在现代软件开发过程中,数据的处理和转换是一项重要的任务。随着互联网的发展,XML(可扩展标记语言)作为一种灵活的数据交换格式,被广泛应用于不同系统之间的数据...
标题中的“使用XSLT将ADO记录集转换为定界文件”是指利用XSL Transformations (XSLT) 技术,将ActiveX Data Objects (ADO) 的Recordset对象转换成以特定分隔符(如逗号、制表符等)分隔的文本文件。在数据处理和交换...
最后,文档涉及了对ADO动态属性的操作,XSLT转换以及XML的安全考虑等高级话题。这部分内容帮助开发者扩展了ADO应用的可能性,比如通过XML DOM对象保存数据,或者对XML格式的记录集进行安全处理。 由于内容是基于...
在实际应用中,这些步骤可能需要根据具体需求进行调整和优化,例如,可以使用XPath或XSLT进行数据筛选和转换,或者利用SQL Server的OPENXML函数和sp_xml_preparedocument存储过程处理XML数据。 总之,XML与SQL ...
对于XML的支持,ADO.NET允许通过XML加载和保存数据集内容,利用DiffGrams进行差异比较,通过XmlDataDocument进行数据集和XML文档的同步,以及使用XPath和XSLT进行查询和转换。XML也被广泛用于在Web服务中传递数据,...
可以通过VB6创建新的项目,添加对ADO的引用,然后使用XMLDSO来加载和操作XML数据,将其绑定到ADO记录集以便进一步处理。 总之,XML的空白字符处理、XML声明、打印可读XML、名称空间的使用以及在VB中利用XMLDSO与XML...
5. XSLT转换:XSL(Extensible Stylesheet Language)用于转换XML数据。VBA可以调用XSLT处理器,应用样式表到XML文档上,生成新的XML或HTML输出。 6. XML Schema验证:MSXML库支持XML Schema,可以用来验证XML文档...
此外,DataSet可以利用XML操作来处理数据,例如使用XSLT进行数据转换或使用XPath查询数据。DataSet的使用场景包括但不限于:需要对记录集合进行缓存以提升性能,对每条记录需要进行大量处理,或需要使用XML操作对...
5. ADO中的独立对象类包括Connection(连接对象)、Command(命令对象)、Recordset(记录集对象)、Field(字段对象)等。 【程序题】题目要求编写JavaScript函数和XML文档的DTD验证,具体实现未给出,但这是测试...
14.9.1 把DataSet转换为XML 14.9.2 把DataSet作为XML访问 14.10 总结 第三部分 构建ASP.NET网站 第15章 用户控件 15.1 用户控件基础 15.1.1 创建简单的用户控件 15.1.2 把页面转换成用户控件 15.2 ...
5. **数据库访问**:讲解如何使用ADO(ActiveX Data Objects)连接和操作数据库,包括SQL查询、记录集、事务处理等内容。 6. **错误处理和调试**:介绍ASP的错误处理机制,如何设置On Error语句进行错误捕获,以及...
7. **XML处理**:XML在数据交换和配置文件中广泛应用,实例可能展示如何读写XML文件、XPath查询、XSLT转换等,帮助开发者理解XML的相关技术。 8. **错误处理与调试**:实例还会包含异常处理机制(try-catch-finally...
5. ADO中的独立对象类包括Connection(连接对象)、Command(命令对象)、Recordset(记录集对象)、Error(错误对象)等。 【程序题略】 由于篇幅限制,这里仅提供问题的大致思路: 1. JavaScript函数isAlpha()应...
此外,XML与XSLT(转换语言)和XPath(导航语言)的关系也会被提及。 PHP是一种服务器端脚本语言,常用于动态网站开发。手册会涉及变量、数组、流程控制、函数、类和对象,以及PHP如何与MySQL等数据库交互。此外,...
14.9.1 把DataSet转换为XML 514 14.9.2 把DataSet作为XML访问 515 14.10 总结 517 第三部分 构建ASP.NET网站 第15章 用户控件 520 15.1 用户控件基础 520 15.1.1 创建简单的用户控件 521 15.1.2 把...
实例源码可以展示如何读取、写入和操作XML文档,以及利用XPath和XSLT进行数据转换。 七、Web服务和WCF VS2005引入了对Web服务的支持,C#可以方便地创建和消费SOAP或RESTful Web服务。此外,Windows Communication ...
11.1.3 将Web窗体转换成用户控件 11.2 自定义控件 11.2.1 实现自定义控件 11.2.2 复合自定义控件 11.3 用户控件和自定义控件的异同 11.4 用户控件示例 11.4.1 ASP.NET登录控件 11.4.2 ASP.NET登录控件的开发 11.4.3 ...
- **ADORecordset与DataSet的区别**:ADORecordset是ADO中用来表示记录集的对象,而DataSet则是ADO.NET中用于表示记录集的对象。两者的主要区别在于DataSet提供了更丰富的数据处理功能,如内置的数据关系管理、数据...