ASP开发中数据库文件调用的捷径

2018-09-06 10:22

阅读:977

  引言
本文针对ASP程序设计中最基础、也是最关键的部分数据库文件的调用进行说明,同时谈谈ASP程序设计中数据库文件调用的一些技巧。

ASP简介

ASP(ActiveServerPages)是微软于1996年推出的Web应用程序开发技术,它是一种脚本语言、ActiveX组件及HTML语言等的综合,微软把它描述为一个服务器的脚本环境,在这里可以生成和运行动态的、交互的、高性能的Web服务器应用程序。其主要功能是为生成动态的、交互式的Web服务器应用程序提供一种功能强大的方式或技术。其特点是命令和脚本都在服务器中解释执行,然后送到客户端浏览器的内容只是标准的HTML页面。其优点是程序设计简单易懂,而且方便快捷。ASP在国内的应用已非常普遍,相当一部分的动态网站都运用了ASP技术。

ASP数据库文件的调用

虽然不同的系统可能安装不同的数据库驱动程序,但一般的服务器系统都基本支持IIS4.0/5.0,所以服务器系统上至少会有MicrosoftAccessDriver、MicrosoftODBCforOracle、SQLServer等3种数据库驱动程序。因此,服务器系统至少可以使用Access、Oracle、SQLServer等3种数据库来从事ASP网页数据库设计。由于MicrosoftAccess97/2000属于微软的Office系列之一,且界面和Office系列软件相似,学习起来基本没什么障碍,因此,本文将从初学者入门的角度,使用Access数据库文件来进行ASP程序设计。

通过Access应用程序制作如图1的数据库文件(friend.mdb)




图1

那么,ASP程序设计中调用该数据库文件有两种方式,一种为直接在控制面板的数据源(ODBC)上进行手工设置;另外一种是编程,通过相对路径调用数据库文件,这种方式可适用在任何一台服务器上而不用再进行配置。第一种方式较为简单安全,本文所谈的是第二种方式。

下面列出ASP程序设计中一般读取数据库文件中表记录的方法:

01:<HTML><BODY>
02:-->
03:<%
04:使用ASP的Connection对象打开数据库,数据库文件为上图的<Friend.mdb>
05:DimobjConn
06:nection)
07:objConn.ConnectionString=Provider=Microsoft.Jet.OLEDB.4.0;&_
08:DataSource=&Server.MapPath(Friend.mdb)
09:objConn.Open
10:读取data表的记录,然后存放在Recordset对象
11:DimobjRS
12:SetobjRS=Server.CreateObject(ADODB.Recordset)
13:ObjRS.Opendata,objConn,adOpenKeyset,adLockOptimistic,adCmdTable
14:将目前指针所指到的记录显示在浏览器上
15:IfNotobjRS.EOFthen
16:Response.Write编号:&objRS(编号)&<BR>
17:Response.Write姓名:&objRS(姓名)&<BR>
18:Response.Write性别:&objRS(性别)&<BR>
19:Else
20:Response.Write到达数据库的结尾,已经显示完所有符合条件的记录
21:EndIf
22:关闭数据库连接并释放对象实例
23:ObjRS.Close
24:SetobjRS=Nothing
25:ObjConn.Close
26:SetobjConn=Nothing
27:%>
28:</BODY></HTML>

上述代码为ASP编程中一般打开Access数据库文件的设计步骤。

数据库文件调用的技巧

(1)事实上,无论换成哪个Access数据库,打开数据库连接与读取表记录的步骤是相同的,其中的变量在于数据库文件的名称及表的名称,所以可以将上述程序的第3~13行改写成函数的形式,并存成一个文件如:ADOFunctions.asp,日后要打开某个数据库文件的话,就把该文件ADOFunctions.asp装(include)进来,代码如下:

<%
DimobjConn
变量Filename为数据库文件名,变量TableName为表名
FunctionGetRecordset(FileName,TableName)
使用ASP的Connection对象打开数据库
SetobjConn=Server.CreateObject(ADODB.Connection)
objConn.ConnectionString=Provider=Microsoft.Jet.OLEDB.4.0;&_
DataSource=&Server.MapPath(Filename)
objConn.Open
读取表的记录,然后存放在Recordset对象objRS
DimobjRS
SetobjRS=Server.CreateObject(ADODB.Recordset)
ObjRS.OpenTableName,objConn,adOpenKeyset,adLockOptimistic,adCmdTable
EndFunction
%>

由上述代码可知,函数名为GetRecordSet,其返回值是存放了表记录的Recordset对象实例,存成文件名为ADOFunctions.asp。现在,利用该文件就可以读取任何数据库文件的记录了。如一般读取数据库的编程可简化如下:

<HTML><BODY>
<!--#Includefile=adovbs.inc-->
<!--#includefile=ADOFunctions.asp-->
<%
调用GetRecordset函数取得一个Recordset对象实F例,然后指派给变量objRS
DimobjRS
SetobjRS=GetRecordset(Friend.mdb,data)
将目前指针所指到的记录显示在浏览器上
IfNotobjRS.EOFThen
Response.Write编号:&objRS(编号)&<BR>
Response.Write姓名:&objRS(姓名)&<BR>
Response.Write性别:&objRS(性别)&<BR>
Else
Response.Write到达数据库的结尾,已经显示完所有符合条件的记录
EndIf
关闭数据库连接并释放对象实例
ObjRS.Close
SetobjRS=Nothing
ObjConn.Close
SetobjConn=Nothing
%>
</BODY></HTML>

因此,只要在这句代码SetobjRS=GetRecordset(Friend.mdb,data)中改变数据库名称和表名称就可以调用任何Access数据库文件了,当然,要注意的是,后面的数据库中每个表的字段名一定要匹配。

(2)另外,无论换成哪个Access数据库,打开数据库连接与筛选表记录的步骤也是相同的,其中的变量在于SQL语句(如:SELECT*FROMdata)、数据库文件的名称及表的名称。因此同样道理,可以将这3个变量作为函数的参数,撰写GetSQLRecordset函数,并存成文件名为ADOSQLFunctions.asp,日后要用到的话,只要在程序的最前面把这个文件Include进来,就可以利用GetSQLRecordset函数打开数据库连接,同时也进行筛选表记录,该函数的返回值是存放了符合SQL语句的Recordset对象实例。

代码如下:

<%
DimobjConn
DimGetSQLRecordset
FunctionGetSQLRecordset(strSQL,FileName,TableName)
使用ASP的Connection对象打开数据库

SetobjConn=Server.CreateObject(ADODB.Connection)
objConn.ConnectionString=Provider=Microsoft.Jet.OLEDB.4.0;&_
DataSource=&Server.MapPath(Filename)
objConn.Open
从表读取符合SQL语句的记录并存放在Recordset对象
SetGetSQLRecordset=Server.CreateObject(ADODB.Recordset)
GetSQLRecordset.Open_strSQL,objConn,adOpenKeyset,adLockOptimistic,adCmdText
EndFunction
%>

上述代码中函数名称为:GetSQLRecordset,文件名为ADOSQLFunctions.asp。

现在,利用该文件就可以调用任何Access数据库的连接,同时对表记录进行筛选的操作。以Friend.mdb文件为例,列出表data中所有的记录,程序代码如下:

<HTML><BODY>
<!--#includefile=adovbs.inc-->
<!--#includefile=ADOSQLFunctions.asp-->
<%
DimobjRS
SetobjRS=GetSQLRecordset(SELECT编号,姓名,性别from_data,Friend.mdb,data)
DoWhileNotobjRS.EOF
Response.Write编号:&objRS(编号)&<BR>
Response.Write姓名:&objRS(姓名)&<BR>
Response.Write性别:&objRS(性别)&<BR>
Loop

objRS.Close
SetobjRS=Nothing
ObjConn.Close
SetobjConn=Nothing
%>
</BODY></HTML>

小结

在ASP编程中,利用好函数往往可以对我们的程序代码简单明了化,读取条理也容易维护,同时也可避免大量的重复繁杂的代码。像上述的情况,若只是简单的与数据库连接,则用第一种情况,将文件ADORecordset.asp装(include)进来就可以了,若要对数据库中某个表的记录进行筛选或其他SQL语句操作,则用第二种情况,将文件ADOSQLRecordset.asp装进来就可以了。


评论


亲,登录后才可以留言!