使用ADO相关技巧与使用习惯
创始人
2024-06-18 03:50:37
0

使用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个字符的产品:

  1. <%  
  2. Dim objRecordset  
  3. Set objRecordset = Server.CreateObject("ADODB.Recordset")  
  4. objRecordset.open _  
  5. "SELECT ProductName, UnitPrice, UnitsInStock " _  
  6. & "FROM Products " _  
  7. & "WHERE UnitPrice <= 20 " _  
  8. & "AND UnitsInStock >= 20 " _  
  9. & "AND LEN(ProductName) <= 6 " _  
  10. & "ORDER BY ProductName", _  
  11. "Provider=SQLOLEDB;" _  
  12. & "Data Source=SomeSQLServer;" _  
  13. & "Initial Catalog=Northwind;" _  
  14. & "User ID=MyUserName;" _  
  15. & "Password=MyPassword;"  
  16. %> 

现在,我们就用3种方式把我们得到的记录集转换成XML格式。首先,使用ADO我们可以遍历整个记录集,采用XML DOM(Document Object Model),建立XML节点树:

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...