社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 5939阅读
  • 1回复

ASP技术访问WEB数据库

级别: 经院博士
发帖
3975
铜板
4727
人品值
1147
贡献值
565
交易币
0
好评度
3833
信誉值
0
金币
0
所在楼道
学一楼
一. 访问WEB数据库的多种方案 wn"}<ka  
  目前在WINDOWS环境下有多种访问WEB数据库的技术,主要有: f~VlCdf+  
  1.公共网关接口CGI(Common Gateway Interface) 5%}e j)@  
  CGI是较早实现的技术。适用于多种服务器平台,如UNIX、WINDOWS等,但CGI的开发 zu d_BOq{f  
成本高、维护困难、功能有限、不具备事务处理功能、占用服务器资源较多。 kY)Vr3uGA  
  2. INTERNET数据库连接器IDC(Internet Database Connector) <Kt_ oxK,  
  IDC集成在ISAPI(Internet Server API)中,充分利用了DLL技术,易扩充,但编程 8?Zhh.  
较CGI更为复杂,只适用于小型数据库系统。 ,@ '^3u  
  3. 先进数据库连接器ADC(Advance Database Connector) "D'e  
  ADC提供了ActiveX Control来访问数据库,它的主要特点是数据查询由用户端浏览 l*l*5hA  
器执行,因而需将服务器端数据库中的部分记录下载到用户端,系统开销较大、响应慢 {s8c@-'  
,只适用于特别频繁的数据库查询操作。 #8Bh5L!SJ1  
  4. JAVA/JDBC语言编程 h%/BZC^L]|  
  JAVA语言是一种面向对象、易移植、多线程控制的语言,可通过JDBC去连接数据库 Tz1^"tx9  
。用JAVA/JDBC编写的软件可移植性强,适用于多种操作系统,但其执行效率和执行速度 v]k-x n|$j  
还不理想,目前无法建立高效、高速的应用。 3RaduN]  
  5. 动态服务器页面ASP(Active Server Page) @:>]jp}uq  
  ASP是微软公司最新推出的WEB应用开发技术,着重于处理动态网页和WEB数据库的开 s+:|b~  
发,编程灵活、简洁,具有较高的性能,是目前访问WEB数据库的最佳选择。 }a;xs};X;  
  二. ASP简介 R /=rNUe  
  1.ASP访问数据库的原理 Bve|+c6W  
  ASP是服务器端的脚本执行环境,可用来产生和执行动态的高性能的WEB服务器程序 oxxuw Dcl  
*L^W[o  
  当用户使用浏览器请求ASP主页时,WEB服务器响应,调用ASP引擎来执行ASP文件, VM$n|[C~  
并解释其中的脚本语言(JScript 或VBScript),通过ODBC连接数据库,由数据库访问组 N`W[Q>n  
件ADO(ActiveX Data Objects)完成数据库操作,最后ASP生成包含有数据查询结果的HT ;FqmZjm  
ML主页返回用户端显示。 e?W ,D0h  
  由于ASP在服务器端运行,运行结果以HTML主页形式返回用户浏览器,因而ASP源程 _wKwiJs  
序不会泄密,增加了系统的安全保密性。此外,ASP是面向对象的脚本环境,用户可自行 w5>[hQR\  
增加ActiveX组件来扩充其功能,拓展应用范围。 ei5YxV6I  
  2.ASP页面的结构: QP\9#D~  
  ASP的程序代码简单、通用,文件名由.asp结尾,ASP文件通常由四部分构成: 3X gJZ  
  1) 标准的HTML标记:所有的HTML标记均可使用。 d6MWgg  
  2) ASP语法命令:位于 标签内的ASP代码。 `vBBJ@f4)  
  3) 服务器端的include语句:可用#include语句调入其它ASP代码,增强了编程的灵 70qEqNoC  
活性。 mG1~rI  
  4) 脚本语言:ASP自带JScript和VBScript两种脚本语言,增加了ASP的编程功能, *^-AOSVt,  
用户也可安装其它脚本语言,如Perl、Rexx等。 @_do<'a  
  3.ASP的运行环境 xX&B&"]5  
  目前ASP可运行在三种环境下。 X$!fR >Zc  
  1) WINDOWS NT server 4.0运行IIS 3.0(Internet Information Server)以上。 d]0:r]e  
  2) WINDOWS NT workstation 4.0运行Peer Web Server 3.0以上。 &qbEF3p^@  
  3) WINDOWS 95/98运行PWS(Personal Web Server)。 ov+{<0Q  
  其中以NT server上的IIS功能最强,提供了对ASP的全面支持,是创建高速、稳定的 27!F B@k-  
ASP主页的最佳选择。 %RD\Sb4YV  
  4.ASP的内建对象 ]W3_]N 3  
  ASP提供了六个内建对象,供用户直接调用: /"e@rnn  
  1) Application对象:负责管理所有会话信息,可用来在指定的应用程序的所有用 ) ^ En  
户之间共享信息。 E^)FnXe5  
  2) Session对象:存贮特定用户的会话信息,只被该用户访问,当用户在不同WEB页 aBC5?V*e%  
面跳转时,Session中的变量在用户整个会话过程中一直保存。Session对象需cookie支 ~9]vd|  
持。 =NY;#Jjn  
  3) Request对象:从用户端取得信息传递给服务器,是ASP读取用户输入的主要方法 OJm ]gb7  
#&.Znk:@.f  
  4) Response对象:服务器将输出内容发送到用户端。 KkUK" Vc  
  5) Server对象:提供对服务器有关方法和属性的访问。 M8-8 T  
  6) Object Context对象:IIS 4.0新增的对象,用来进行事务处理。此项功能需得 M@T{uo  
到MTS(Microsoft Transcation Server)管理的支持。 L-Q8iFW'  
  5. ASP的主要内置组件: "w?0f["  
  1) Ad Rotator组件:用来按指定计划在同一页上自动轮换显示广告,用于WWW上日 %2:UsI  
益重要的广告服务。 <6(0ZO%,C!  
  2) Browser Capabilities组件:确定访问WEB站点的用户浏览器的功能数据,包括 s",Ea*  
类型、性能、版本等。 Sn[xI9}O  
  3) Database Access组件:提供ADO (ActiveX Data Objects)来访问支持ODBC的数 j/aJDE(+  
据库。 neU=1socJ  
  4) File Access组件:提供对服务器端文件的读写功能。 E+Bc>xl@ m  
  5) Content Linking组件:生成WEB页内容列表,并将各页顺序连接,用于制作导航 J'2 Yrn  
条。 XHA|v^  
  此外,还可安装Myinfo、Counters、Content Rotator、Page Count等组件,用户也 Gor 9 &aJ1  
可自行编制Actiive组件,以提高系统的实用性。 IT NFmD  
  6. Database Access组件ADO k' 8q /]  
  WWW上很重要的应用是访问WEB数据库,用ASP访问WEB数据库时,必须使用ADO组件, -Mr_Ao`E  
ADO是ASP内置的ActiveX服务器组件(ActiveX Server Component),通过在WEB服务器上 bo#xqSGQ  
设置ODBC和OLEDB可连接多种数据库:如SYBASE、ORACLE、INFORMIX、SQL SERVER、ACC gs1yWnSv5  
ESS、VFP等,是对目前微软所支持的数据库进行操作的最有效和最简单直接的方法。 0m3hL~0(a  
  ADO组件主要提供了以下七个对象和四个集合来访问数据库。 7>f2P!:  
  1) Connection对象:建立与后台数据库的连接。 H|aFs.SEQ  
  2) Command对象:执行SQL指令,访问数据库。 ` +YtTK  
  3) Parameters对象和Parameters集合:为Command对象提供数据和参数。 +=/j+S`  
  4) RecordSet对象:存放访问数据库后的数据信息,是最经常使用的对象。 Sqi9'-%m  
  5) Field对象和Field集合:提供对RecordSet中当前记录的各个字段进行访问的功 )<HvIr(xr  
能。 T8m]f<  
  6) Property对象和Properties集合:提供有关信息,供Connection、Command、Re 9&r]k8K  
cordSet、Field对象使用。 VKPEoy8H  
  7) Error对象和Errors集合:提供访问数据库时的错误信息。 C rR/  
  三. ASP访问数据库步骤 #U-y<[ 3  
  在ASP中,使用ADO组件访问后台数据库,可通过以下步骤进行: .QP`Qn6(P  
  1. 定义数据源 s O#cJAfuu  
  在WEB服务器上打开“控制面板”,选中“ODBC”,在“系统DSN”下选“添加”, yhgGvyD  
选定你希望的数据库种类、名称、位置等。本文定义“SQL SERVER”,数据源为“HT” 3PkZXeH/  
,数据库名称为“HTDATA”,脚本语言采用Jscript。 pmP~1=3  
  2,使用ADO组件查询WEB数据库 {*;8`+R&  
  1) 调用Server.CreateObject方法取得“ADODB.Connection”的实例,再使用Open 7l7VT?<:  
方法打开数据库: gE#|eiu  
  conn = Server.CreateObject(“ADODB.Connection”)  B=*0  
  conn.Open(“HT”) v FL$wr  
  2) 指定要执行的SQL命令 l1]N&jN{  
  连接数据库后,可对数据库操作,如查询,修改,删除等,这些都是通过SQL指令来 D`QMlRzXy  
完成的,如要在数据表signaltab中查询代码中含有“X”的记录 c9c]1XJ  
  sqlStr = “select * from signaltab where code like ‘%X%’” EPW4 h/I  
  rs = conn.Execute(sqlStr) |-6`S1.  
  3) 使用RecordSet属性和方法,并显示结果 \j!/l f)  
  为了更精确地跟踪数据,要用RecordSet组件创建包含数据的游标,游标就是储存在 n`^jNXE  
内存中的数据。 ^;/~$  
  rs = Server.CreateObject(“ADODB.RecordSet”) 1$DcE>  
  rs.Open(sqlStr,conn,1,A) 7Wef[N\x  
  注:A=1读取 D?y-Y  
  A=3 新增、修改、删除 *JImP9SE  
  在RecordSet组件中,常用的属性和方法有: `ZL^+h<b>M  
  rs.Fields.Count: RecordSet对象的字段数。 J jZB!Lg=  
  rs(i).Name: 第i个字段的名称,i为0至rs.Fields.Count-1 T x Mh_  
  rs(i): 第i个字段的数据,i为0至rs.Fields.Count-1 A)~ oD_ooQ  
  rs(字段名): 指定字段的数据。 _886>^b@  
  rs.Record.Count:游标中的数据记录总数。 +8ib928E  
  rs.EOF: 是否最后一条记录。 Z?S?O#FED  
  rs.MoveFirst: 指向第一条记录。 5 `TMqrk  
  rs.MoveLast: 指向最后一条记录。 waz5+l28  
  rs.MovePrev: 指向上一条记录。 RUr ~u  
  rs.MoveNext: 指向下一条记录。 [BdRx`  
  rs.GetRows: 将数据放入数组中。 }{+?>!qDt  
  rs.Properties.Count:ADO的ResultSet或Connection的属性个数。 #O_%!7M{4  
  rs.Properties(item).Name:ADO的ResultSet或Connection的名称。 a 7v^o`  
  rs.Properties: ADO的ResultSet或Connection的值。 !DA4q3-U>>  
  rs.close(): 关闭连接。 (ID%U  
  4) 关闭数据库 \<9aS Y'U  
  conn.close() Wk^{Tn/]  
  四.查询WEB数据库举例 f\?Rhyz  
  下面这段示例程序是访问SQL SERVER数据库的 signaltab表,表中有三个字段:co B!<B7Q  
de(代码字段,字符型,3位),class(分类字段,字符型,10位),memo(备注字段,字符 _ LgP  
型,20位)。程序中数据源DSN:HT、用户名:client、口令:passwd。 851BOkRal4  
  屏幕输入页面input.asp Gfx !.[Y  
   z z]~IxQ  
   ;R&W#Q7>3  
   IA}vN3  
  请输入查询条件PLEASE INPUT CONDITION s8:epcL`A  
   Y\<w|LkD8  
   i+QVs_jW  
   29 !QE>Q  
   vC&0UNe$  
   3;b)pQ~6CJ  
   5o{U$  
   GYy8kp84  
   )Dms9:  
   C3.]dsv:  
   l %zbx"%x  
   s`Z.H5V>\  
   2OI 0B\  
  数据库处理程序shotquery.asp .mwW`D  
   ;L",K?6#  
   r9-ayp#pC  
  var signalCode=Request.Form(signalCode); zGme}z;1@  
  dbConn = Server.CreateObject(ADODB.Connection); >8{{H"$;(  
  dbConn.open(DSN=HT;UID=client;PWD=passwd); rpEIDhHv  
  rs = Server.CreateObject(ADODB.RecordSet); O|Vc  
  var sqlStr = select * from signaltab order by code; kDJqT  
  rs.open(sqlStr,dbConn,1); Z;u3G4XlF  
  if(rs.RecordCount     无符合条件记录); Dg~m}La  
  Response.write(     ); &RuTq6)r  
  } Qhe<(<^J,  
  else { m0 W3pf  
  Response.write(数据查询结果); 82)=#ye_P  
  Response.write(代码分类备注); ]) v61B  
  for(var i = 1;i +rs(code)+); ,6^Xn=o #  
  Response.write(+rs(class)+); Y1AZ%{^0a  
  Response.write(+rs(memo)+); Nz"K`C>/  
  Response.write(); g"!cO^GkT  
  rs.MoveNext(); @D["#pe,}  
  } 1W.oRD&8j/  
  else break; J 7dHD(R8  
  } %H_-`A`  
  Response.write(); npytb*[|c  
  rs.close(); u"T9w]Z\  
  dbConn.close(); 'lEIwJV$  
  } GM8>u O  
   "Ar|i8^G3  
'b[O-6v  
it>Bf;  
:%28*fl  
转自: ASP教程采集
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水
引用

引用
想找我?如果我即不在 石家庄经济学院论坛www.uebbs.net,也不在宿舍,那,我肯定是在去的路上

引用
级别: 经院高中
发帖
369
铜板
3800
人品值
215
贡献值
0
交易币
0
好评度
305
信誉值
0
金币
0
所在楼道
只看该作者 1 发表于: 2006-07-20
这篇不评论了........
描述
快速回复

您目前还是游客,请 登录注册
如果您在写长篇帖子又不马上发表,建议存为草稿
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八