利用XSLT把ADO记录集转换成XML(1)[转载]

转载 2006年06月03日 19:55:00
利用XSLT把ADO记录集转换成XML(1)
http://www.51cto.com 2005-11-04 09:36 出处:51cto.com整理
 
 
 

 

由于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实现XML文档转换成HTML文档

XML文档描述了数据的结构,并且可以用自定义的标记元素描述数据意义,而且实现了记录数据的功能。如果想要将XML的数据显示在网页页面上,如何做呢? 最简单的方式就是将XML文件直接用浏览器打开...
  • xqf309
  • xqf309
  • 2012-10-22 20:42
  • 9308

纯数据xml通过xslt转换成报表xml

一、 除了要知道xml,xslt的知识,还需要了解ExcelXml(可用Excel打开的报表xml)各标签的含义。 数据放在标签的标签内。 每一行数据放在标签内,每个单元格的内容放在标签内 每...

ADO记录集相关知识

1.打开记录集 首先要创建一个Connection对象实例,然后执行Open方法打开记录集。例如: m_strConnection = _T("Provider=Microsoft.Jet.OLE...

VC ado调用oracle执行存储过程获取记录集

最近在做一个项目,数据库是用SQL Server,不过最近突然来了个需求说要改用Oracle。之前对SQL Server ado访问层做了一些封装,想试试看能不能简单修改后兼容oracle。测试过程中...
  • imlmy
  • imlmy
  • 2013-05-07 14:33
  • 2350

JAVA利用XSLT进行格式转换,XML转成自己需要的XML、HTML等。

JAVA利用XSLT进行格式转换,XML转成自己需要的XML、HTML等。

利用ORACLE的MINUS函数,直接实现两个记录集的比较

1 引言   在程序设计的过程中,往往会遇到两个记录集的比较。如华东电网PMS接口中实现传递一天中变更(新增、修改、删除)的数据。实现的方式有多种,如编程存储过程返回游标,在存储过程中对两批数据进行...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)