利用xslt把ado记录集转换成xml

利用xslt把ado记录集转换成xml

ID:5327598

大小:112.18 KB

页数:13页

时间:2017-12-08

利用xslt把ado记录集转换成xml_第1页
利用xslt把ado记录集转换成xml_第2页
利用xslt把ado记录集转换成xml_第3页
利用xslt把ado记录集转换成xml_第4页
利用xslt把ado记录集转换成xml_第5页
资源描述:

《利用xslt把ado记录集转换成xml》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、利用XSLT把ADO记录集转换成XML由于XML(可扩展标记语言:eXtensibleMarkupLanguage)真正的平台无关性,它正在逐渐成为数据传输的主要介质。XML是一种自描述的语言,数据本身就已经包含了元数据,即关于数据本身的信息。例如:“孟子E章1757281793923net_lover1807581793923”这组数据,从字面很难看出它代表什么意思,也不清楚它有几个数据段组成,但是,如果用XML来做如下的描述,我们就可以清楚地看到每个数据段所代表的含义:<姓名>孟子E章<身高>175<体重

2、>72<电话>81793923<姓名>net_lover<身高>180<体重>75<电话>81793923从上面的一段XML中,我们不但可以清楚地看到每一个数据代表的是什么意思了,而且还可以知道数据的分割位置。在我们平常的应用中,我们得到的结果可能是数组、集合或记录集的表现形式,我们该如何把它们转换成自描述的XML格式的数据呢?从数据形式上看,XML是简单的纯字符串的文本格式,字符串在传递时是非常简单、快速而且是容易的,数组在通过引

3、用进行传递时有时是很慢的,而且处理起来很麻烦,而集合和记录集都是对象,在处理时会导致计算机性能的下降,并且这些对象都是与特定的平台相关联的,这就要求平台有内建的处理机制来处理对象的操作。XML已经是W3C的标准,是平台无关的,我们的计算机的唯一要求就是能够处理简单的XML字符串,即XML解析器,它能够解析XML字符串,能够通过一种接口很容易地把数据分解成一个个独立的数据段,以便我们能够进行访问。XML解析器都很小,性能也很好,在每种平台上都可以找到。一旦我们接收到XML数据并把它解析成上面的例子的样式后,我们就可以通过XSLT(eXstensibleStyleshee

4、tLanguageTransformations)把他们转换成不同的表现形式。利用XML的数据格式进行数据传输,将会使我们编写应用程序代码的工作更简单轻松,而且具有良好的可伸缩性。下面,我们就看看如何来转换我们的数据。我们的例子是在Microsoftwindows2000,IIS5,MSXML3和ADO2.6下编写的,样例数据采用MicrosoftSQLServer7.0自带的Northwind示例数据库。之所以采用SQLServer7而不采用支持XML的SQLServer2000,是考虑到通用性的原则,我们的目的是:处理不同类型的数据源得到的记录集,而不仅仅是象SQ

5、LServer2000那样的支持XML输出的数据源。使用ADO,是因为它形式多样,可以处理不同类型的数据源;使用XML,是因为它能够快速传输和解析。但本例的处理方法也适合在任何具有MicrsoftXML解析器,ADO2.5或以上版本的Windows,IIS,SQLServer的环境中。为简单起见,我们仅选择单价小于等于20美圆,库存大于等于20,产品名称小于等于6个字符的产品:<%DimobjRecordsetSetobjRecordset=Server.CreateObject(“ADODB.Recordset”)objRecordset.open_“SELECTP

6、rodUCtName,UnitPrice,UnitsInStock”_&“FROMProducts”_&“WHEREUnitPrice<=20”_&“ANDUnitsInStock>=20”_&“ANDLEN(ProductName)<=6”_&“ORDERBYProductName”,_“Provider=SQLOLEDB;”_&“DataSource=SomeSQLServer;”_&“InitialCatalog=Northwind;”_&“UserID=MyUserName;”_&“PassWord=MyPassword;”%>现在,我们就用3种方式把我们得到

7、的记录集转换成XML格式。首先,我们可以遍历整个记录集,采用XMLDOM(DocumentObjectModel),建立XML节点树:<%DimobjXMLDOM,objRootNode,objNodeSetobjXMLDOM=Server.CreateObject(“MSXML2.DOMDocument”)SetobjRootNode=objXMLDOM.createElement(“xml”)objXMLDOM.documentElement=objRootNodeDoWhileNOTobjRecordset.EOFSetobjRowNode=o

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。