分享
 
 
 

ASP开发中数据库文件调用

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

引言

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

ASP简介

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

ASP数据库文件的调用

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

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

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

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

01: <HTML><BODY>

02: <!--#include file="adoVBs.inc"-->

03: <%

04: ’使用ASP的Connection 对象打开数据库,数据库文件为上图的<Friend.mdb>’

05: Dim objConn

06: Set objConn=Server.CreateObject("ADODB.Connection")

07: objConn.ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;" &_

08: "Data Source=" & Server.MapPath("Friend.mdb")

09: objConn.Open

10: 读取"data"表的记录,然后存放在Record set对象

11: Dim objRS

12: Set objRS=Server.CreateObject("ADODB.Recordset")

13: ObjRS.Open "data",objConn,adOpenKeyset,adLockOptimistic,adCmdTable

14: ’将目前指针所指到的记录显示在浏览器上

15: If Not objRS. EOF then

16: Response.Write "编号:"&objRS("编号")& "<BR>"

17: Response. Write "姓名:"&objRS("姓名")& "<BR>"

18: Response. Write "性别:"&objRS("性别")& "<BR>"

19: Else

20: Response.Write "到达数据库的结尾,已经显示完所有符合条件的记录"

21: End If

22: ’关闭数据库连接并释放对象实例

23: ObjRS. Close

24: Set objRS=Nothing

25: ObjConn.Close

26: Set objConn=Nothing

27: %>

28: </BODY></HTML>

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

数据库文件调用的技巧

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

<%

Dim objConn

’变量Filename为数据库文件名,变量Table Name为表名

Function GetRecordset(FileName,TableName)

’使用ASP的Connection 对象打开数据库

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

objConn.ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;" &_

"Data Source=" & Server.MapPath("Filename")

objConn.Open

’读取表的记录,然后存放在Record set对象"objRS"

Dim objRS

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

ObjRS.Open TableName,objConn,adOpenKeyset,adLockOptimistic,adCmdTable

End Function

%>

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

<HTML><BODY>

<! --#Include file="adoVBs.inc"-->

<! --#include file="ADOFunctions.asp"-->

<%

’调用GetRecordset函数取得一个Record set对象实F例,然后指派给变量objRS

Dim objRS

Set objRS=GetRecordset("Friend.mdb","data")

’将目前指针所指到的记录显示在浏览器上

If Not objRS.EOF Then

Response.Write "编号:"&objRS("编号")& "<BR>"

Response.Write "姓名:"&objRS("姓名")& "<BR>"

Response.Write "性别:"&objRS("性别")&"<BR>"

Else

Response.Write "到达数据库的结尾,已经显示完所有符合条件的记录"

End If

’关闭数据库连接并释放对象实例

ObjRS. Close

Set objRS=Nothing

ObjConn.Close

Set objConn=Nothing

%>

</BODY></HTML>

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

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

代码如下:

<%

Dim objConn

Dim GetSQLRecordset

Function GetSQLRecordset(strSQL,FileName,TableName)

’使用ASP的Connection 对象打开数据库

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

objConn.ConnectionString="Provider=Microsoft.Jet.OLEDB.4.0;" &_

"Data Source=" & Server.MapPath("Filename")

objConn.Open

’从表读取符合SQL语句的记录并存放在Record set对象

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

GetSQLRecordset.Open_ strSQL,objConn,adOpenKeyset,adLockOptimistic,adCmdText

End Function

%>

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

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

<HTML><BODY>

<!--#include file="adoVBs.inc"-->

<!--#include file="ADOSQLFunctions.asp"-->

<%

Dim objRS

Set objRS=GetSQLRecordset("SELECT 编号,姓名,性别from_ data","Friend.mdb","data")

Do While Not objRS.EOF

Response.Write "编号:"&objRS("编号")&"<BR>"

Response.Write "姓名:"&objRS("姓名")&"<BR>"

Response.Write "性别:"&objRS("性别")&"<BR>"

Loop

objRS.Close

Set objRS=Nothing

ObjConn.Close

Set objConn=Nothing

%>

</BODY></HTML>

小结

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有