ASP 3.0高级编程(三十七)

2008-02-23 05:38:57来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

8.2.5 Stream对象
Stream对象用于访问节点的内容,比如一个E-Mail消息,或一个Web页面。利用Stream对象可以访问文件或资源的真实内容。因此,结合Record和Recordset对象,不仅可以访问Web服务器上的文件或email消息,还可以访问相应的内容。这样,就可以创建一个只使用ADO去访问邮件系统的邮件客户。这也许不会有太多的优点,但意味着可不必了解邮件系统的API或对象模型,减少了学习上的弯路。
Stream的另一个用途是XML,可以访问一系列作为XML流的数据(结构化或半结构化)。
Stream对象用来处理二进制数据,所以,可以用来处理BLOB类型的数据,比如数据库中的图像或大文本数据。
同样,在本书第11、12章中你会看到更多的有关Stream对象的例子。

8.2.6 集合
ADO对象库中有一些集合,每个集合都有零个或更多个与其关联的对象的拷贝。可以使用相同的代码结构去遍历这些集合。
在VBScript中的语法是:
For Each object In Collection
' Do something with object
Next
例如,遍历一个Recordset对象的Fields集:
For Each objField In rs.Fields
Response.Write objField.Name & "<BR>"
Next
如果选择JScript,那么可以使用Enumerator对象:
for (objField = new Enumerator(rs.Fields);
!objField.atEnd(); objField.moveNext())
Response.Write (objField.item().Name '<BR>');
1. Fields集合
Fields集合拥有与记录集或记录关联的Field对象。对基于结构化数据的记录集,比如SQL数据,字段相应于数据中的列,并含有列的详细内容,比如名称、数据类型、长度等等。在以后几章看到大量的关于Fields集合的例子。
对于半结构化的数据,对象的属性相应于字段。在第12章会看到更多的相关的介绍。
2. Parameters集合
Parameters集合仅被Command对象使用,确定在存储命令中的参数。SQL数据库中的存储过程频繁地使用参数,并允许数据传入和传出预定义的SQL语句。如果拥有向ADO返回信息的参数,则会十分有用,因为这样从存储过程中返回的就不只是一个记录集。例如,考虑一个更新多个表然后返回一个记录集的复杂存储过程,可以用一个输出参数显示更新了多少条记录。
另一个使用参数的理由是性能问题,特别是在仅仅需要从存储过程返回单个值的时候。在这种情况下,没有创建记录集的必要,只需要保存一个值即可,因而不需要返回记录集,而返回输出参数的值是更为有效的方法。
在第9章会看到有关Parameter集合的详细介绍。
3. Error集合
Error集合包含因运行命令而引起的上一次ADO或OLE DB提供者错误的详细内容,只能被Connection对象访问。可能会觉得这是个限制,因为不必显式定义Connection对象,但可以通过Command、Recordset和Record对象的ActiveConnection属性访问隐含的Connection对象。例如:
For Each objError In rs.ActiveConnection.Errors
Response.Write objError.Name & "<BR>"
Next
在本章后面,将详细讨论Error集合。
4. Properties集合
为了避免混乱,Properties集合没有在前面的对象模型图上加以显示。它与对象模型的关系显示在图8-5中:
图8-5 Property与对象之间的关系
Properties集合存在的原因是因为ADO是用来处理许多不同的数据存储,都有不同的特征。将属性(Property)组成一个集合,可以使之能够动态地根据不同的数据提供者而随时改变。例如,Jet的OLE DB提供者允许访问Jet特殊的安全属性:
Set conDB = Server.CreateObject ("ADODB.Connection")
conDB.Open "DSN=Nwind"

conDB.Properties ("Jet OLEDB:Database Password") = "LetMeIn"
其他的提供者没有这个属性,因此把它加到Connection对象中作为一个静态属性是不明智的。ADO根据所使用的OLE DB提供者,会用提供者缺省值填充属性集合。
虽然这里有关于Properties集合的使用说明,但在本书中不准备详细叙述Properties集合。要获得更多的关于该集合的介绍,请参阅《Professional ADO 2.5 Programming》或《ADO 2.5 Programming's Reference》,两者都由Wrox出版。

8.2.7 ADO常数
当使用ADO时,会发现有许多预先定义的用于众多选项的常数,比如定义光标类型和锁类型的常数。使用像Visual Basic或Visual C 这样的语言,一旦引用了ADO类型库,自然会用到这些常数。在ASP中情况不同,有两种选择。
引用常数的第一种方法是把它们包含进ASP文件:
<!-- #INCLUDE FILE="adovbc.inc" -->
可以将包含文件拷入本地目录,或者从安装目录引用它,其缺省路径为C:\Program Files\Common Files\System\ado(以上文件包含用于VBScript的ADO常数——对于JScript,应该使用adojavas.Inc)。使用这个方法的一点不足是会使ASP页面变得过大,因为包含了全部的常数,而其中许多是不需要使用的。
可以创建自己的只含有所需要的常数的包含文件,但越来越多使用ADO的功能时,很可能会发现需要不断地编辑、维护这个文件。
一个比较好的解决的方法是创建一个对类型库的引用,这种方法不需要将常数包含进ASP文件而直接可以引用常数:
<!-- METADATA TYPE="typelib" FILE="C:\Program Files\
Common Files\System\ado\msado15.dll" -->
不要怀疑这个DLL的名字是msado15.dll,这是一个正确的名字,包含最新版本的ADO。
可以在需要的地方把这个METADATA语句包含进每一个ASP文件,或者放入global.asa文件,这样应用程序中的每个Web页面都可以引用这些常数。

8.3 连接到数据存储
如果需要访问一个数据存储,应该创建一个到数据存储的连接。前面已经提到过:可以显式地创建一个Connection对象,或者让ADO隐含地创建一个连接。对于任何一种方式,都必须知道数据存储的详细内容。
虽然用于连接的实际细节不尽相同,但对于所有类型的数据存储,其连接的实际方法是相同的。这并不令人惊奇,因为不同的提供者需要不同类型的信息。在允许用户访问数据存储之前,一些提供者需要用户的证书,而别的提供者却接受默认的安全证书。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:ASP 3.0高级编程(三十六)

下一篇:ASP 3.0高级编程(三十八)