您的位置:寻梦网首页编程乐园ASP编程ASP教程及使用技巧

ADO

(译自《Visual Basic Programmer's Guide to Web Delelopment》)

ADO是什么?我也不大说得清,只知道他是Active Data Object的缩写,可以当成是一种访问数据的方法吧,就象DAO,RDO一样,我想.

但是,RDO和DAO都是在ODBC规程下开发的,以ODBC为基础,而ADO是在OLE DB规程下开发的,该规程据说是用C++开发的,所以有面向对象的特性.

在OLE DB中,有两个概念,数据消费者和数据提供者,这些东东有些复杂,我就懒得去管他了:-)

1. ADO编程模式

1.1 接口概述

.Connection(连接):Connection接口表示正在使用的数据源和ADO接口之间的连接.

.Error(错误):由数据源返回的错误信息.

.Command(命令):表示一个能被数据提供者处理的命令(查询或语句),用他可以返回一个Recordset记录集或执行一个查询动作.

.Parameter(参数):表示传给Command的参数.

.Recordset:这个最复杂,但是功能最强,他"包含数据的游标",至于"游标",我把他理解成在内存中的数组,不知对不对.

.Field(字段):Recordset中的某一列数据.

1.2 接口的创建

ADO接口与其他概念中的对象不一样的是,他不须派生,大多数对象都可以直接创建(Field和Error除外),在ADO中,没有对象的分级结构.

下面是一个例子:

<%

Set lrs=Server.CreateObject("ADODB.Recordset")

lsSql="SELECT au_id,au_lname,au_fname FROM author"

lrs.Open lsSql,"DSN=Sample;UID=sa;PWD=;DATABASE=pubs"

Response.Write lrs("au_lname")

Response.Write lrs("au_fname")

Response.Write lrs("au_id")

%>

(译注,这个例子我在SQLServer上没有成功,我的IIS是4.0,我用下述方法:

<%

Set conn=Server.CreateObject("ADODB.Connection")

conn.open "Sample","sa",""

sql="SELECT au_id,au_lname,au_fname FROM author"

Set lrs=conn.Exectue(sql)

......

%>

 

1.3 对象的作用范围

我们都知道,HTTP协议是无状态的协议,你不能指望在调用了这个HTML文件后保存一个状态,供调下一个文件时使用.但ASP却可以实现,我们在第六讲中提到Session对象,他缺省地能保持一个会话20分钟,我们就能利用这一点维持数据库连接.一个典型的应用是我们一次返回数据库的20条记录.

我们可以这么做:

<%

Set conn=Server.CreateObject("ADODB.Connection")

conn.open "Sample","sa",""

sql="SELECT au_id,au_lname,au_fname FROM author"

Set lrs=conn.Exectue(sql)

Set Session("lrs")=lrs

.....

Response.Write(Session("lrs")("au_lname"))

....

%>

2. 使用ADO

2.1 创建DSN

DSN的创建,我已在前面文章讲过.

2.2 安全考虑

ASP曾经有一个安全漏洞,你可以在ASP文件的URL最后简单地加一个句号(.),或者加上::$DATA,例如:http://127.0.0.1/asp/test.asp::$DATA

你会看到浏览器显示的不是经过处理的结果,而是ASP源代码!(我去试过一些网站,包括微软的,已经不行了^_^,只有我自己的PWS还可以看到)

3. Connection接口

3.1

Connection接口是数据源的一个开放连接.你可以把他看成是DAO中的Database对象,或者RDO中的rdoConnection.

在你用ASP文件中的Connection接口做任何事之前,必须首先创建他.注意创建与打开他是两回事.下面是创建代码:

Set mconn=Server.CreateObject("ADODB.Connection")

然后打开:

mconn.Open "ODBC;DATABASE=pubs;UID=sa;DSN=pub"

(译注:我还是建议用下面的方法:

mconn.Open "dsnname","username","password"

White Saillor)

3.2 Connection的方法

.Open方法

用来初始化一个连接.只有等到你使用了Connection对象的Open方法,Connection对象才真正存在.(?我不大懂)

.Close方法

当你调用了Close方法时,就停止了与数据提供者的连接,并释放与之关联的系统资源.但并没有释放Connection对象本身.(也就是说,你可以又调用Open方法连接新的数据源)

.BeginTrans方法

.ComitTrans方法

.RollbackTrans方法

.Execute方法

Connection对象也能用来执行SQL语句及存储过程,但有一点须说明的是,他返回的信息是最基本的游标,只能读和只能向前移动的游标.

调用方法:

Set RecordSet=Connection.Execute(CommandText,RecordAffected,Options)

其中,CommandText是一个串,可以用一个标准的SQL语句,RecordAffected是一个变量,返回命令执行时影响的记录数,Options参数定义传给Execute的命令串的类型

可为:

1.adCmdText:表明参数串是SQL串

2.adCmdTable:是表名

3.adCmdStoreProc:是数据提供者知道的存储过程

4.adCmdUnknown:不清楚

3.3 Connection的属性

.Attributes,定义了处理事物的方法

.CommandTimeout,定义允许对数据源操作的命令终止并产生一个错误的等待时间

.ConnectionString,相当与调用Execute时给的第一个参数

.ConnectionTimeout,定义在放弃连接并产生一个错误前等待数据源响应的时间

.DefaultDatabase,定义在连接中使用的缺省数据库

.Provider,返回连接的数据提供者的名字