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

ASP技术访问WEB数据库

级别: 经院博士
发帖
3975
铜板
4727
人品值
1147
贡献值
565
交易币
0
好评度
3833
信誉值
0
金币
0
所在楼道
学一楼
一. 访问WEB数据库的多种方案 S~8w-lG!  
  目前在WINDOWS环境下有多种访问WEB数据库的技术,主要有: #SHmAB  
  1.公共网关接口CGI(Common Gateway Interface) Xm|Uz`A;  
  CGI是较早实现的技术。适用于多种服务器平台,如UNIX、WINDOWS等,但CGI的开发 f1a >C  
成本高、维护困难、功能有限、不具备事务处理功能、占用服务器资源较多。 3H_mR j9th  
  2. INTERNET数据库连接器IDC(Internet Database Connector) y;!qE~!3  
  IDC集成在ISAPI(Internet Server API)中,充分利用了DLL技术,易扩充,但编程 `Jvy~T  
较CGI更为复杂,只适用于小型数据库系统。 bN ,>,hj  
  3. 先进数据库连接器ADC(Advance Database Connector) aAlES< r  
  ADC提供了ActiveX Control来访问数据库,它的主要特点是数据查询由用户端浏览 LIo3a38n?y  
器执行,因而需将服务器端数据库中的部分记录下载到用户端,系统开销较大、响应慢 hdw-gem{?  
,只适用于特别频繁的数据库查询操作。 (6aSDx Sc  
  4. JAVA/JDBC语言编程 $#cZJ@;]  
  JAVA语言是一种面向对象、易移植、多线程控制的语言,可通过JDBC去连接数据库 'THcO*<  
。用JAVA/JDBC编写的软件可移植性强,适用于多种操作系统,但其执行效率和执行速度 92@/8,[  
还不理想,目前无法建立高效、高速的应用。 JYY:~2  
  5. 动态服务器页面ASP(Active Server Page) ;{n@hM*O  
  ASP是微软公司最新推出的WEB应用开发技术,着重于处理动态网页和WEB数据库的开 e b])=  
发,编程灵活、简洁,具有较高的性能,是目前访问WEB数据库的最佳选择。 .H M1c  
  二. ASP简介 6z/ct|n  
  1.ASP访问数据库的原理 %{fa . >6  
  ASP是服务器端的脚本执行环境,可用来产生和执行动态的高性能的WEB服务器程序 4k HFfc  
RGeM.  
  当用户使用浏览器请求ASP主页时,WEB服务器响应,调用ASP引擎来执行ASP文件, :QndeUw  
并解释其中的脚本语言(JScript 或VBScript),通过ODBC连接数据库,由数据库访问组 -:hiLZJ7-  
件ADO(ActiveX Data Objects)完成数据库操作,最后ASP生成包含有数据查询结果的HT <K~> :4c  
ML主页返回用户端显示。 9>t  
  由于ASP在服务器端运行,运行结果以HTML主页形式返回用户浏览器,因而ASP源程 9@Iz:!oqb  
序不会泄密,增加了系统的安全保密性。此外,ASP是面向对象的脚本环境,用户可自行 ')d&:K*M  
增加ActiveX组件来扩充其功能,拓展应用范围。 NF}QQwG3  
  2.ASP页面的结构: $[L8UUHY<8  
  ASP的程序代码简单、通用,文件名由.asp结尾,ASP文件通常由四部分构成: P9Gjsu #  
  1) 标准的HTML标记:所有的HTML标记均可使用。 &B^zu+J  
  2) ASP语法命令:位于 标签内的ASP代码。 yqy5i{Y  
  3) 服务器端的include语句:可用#include语句调入其它ASP代码,增强了编程的灵 (1 "unP-  
活性。 N2?o6)  
  4) 脚本语言:ASP自带JScript和VBScript两种脚本语言,增加了ASP的编程功能, Vvth,  
用户也可安装其它脚本语言,如Perl、Rexx等。 3'd(=hJ45$  
  3.ASP的运行环境 ){AtV&{$  
  目前ASP可运行在三种环境下。 pJ` M5pF  
  1) WINDOWS NT server 4.0运行IIS 3.0(Internet Information Server)以上。 ]x8_f6;D  
  2) WINDOWS NT workstation 4.0运行Peer Web Server 3.0以上。 h,Y!d]2w  
  3) WINDOWS 95/98运行PWS(Personal Web Server)。 Quc,,#u  
  其中以NT server上的IIS功能最强,提供了对ASP的全面支持,是创建高速、稳定的 F:PaVr3q  
ASP主页的最佳选择。 7,i}M  
  4.ASP的内建对象 *wgHa6?+7  
  ASP提供了六个内建对象,供用户直接调用: *V\z]Dy-[  
  1) Application对象:负责管理所有会话信息,可用来在指定的应用程序的所有用 /Hox]r]'e  
户之间共享信息。 iqzl(9o.D  
  2) Session对象:存贮特定用户的会话信息,只被该用户访问,当用户在不同WEB页 vy ME  
面跳转时,Session中的变量在用户整个会话过程中一直保存。Session对象需cookie支 oD$8(  
持。 *K9I+t"g  
  3) Request对象:从用户端取得信息传递给服务器,是ASP读取用户输入的主要方法 |ZEZ@y^  
S$CO T)7  
  4) Response对象:服务器将输出内容发送到用户端。 z7[TgL7  
  5) Server对象:提供对服务器有关方法和属性的访问。 K[wOK  
  6) Object Context对象:IIS 4.0新增的对象,用来进行事务处理。此项功能需得 |x2 +O  
到MTS(Microsoft Transcation Server)管理的支持。 1'skCR|!<  
  5. ASP的主要内置组件: ^i"C%8  
  1) Ad Rotator组件:用来按指定计划在同一页上自动轮换显示广告,用于WWW上日 HF9\SVR B  
益重要的广告服务。 vybQ}dscn  
  2) Browser Capabilities组件:确定访问WEB站点的用户浏览器的功能数据,包括 yIm@m[B;  
类型、性能、版本等。 9uXuV$.  
  3) Database Access组件:提供ADO (ActiveX Data Objects)来访问支持ODBC的数 U>q&p}z0 H  
据库。 AN!MFsk  
  4) File Access组件:提供对服务器端文件的读写功能。 Sv*@3x  
  5) Content Linking组件:生成WEB页内容列表,并将各页顺序连接,用于制作导航 ISQC{K']J  
条。 }Pm>mQZ},  
  此外,还可安装Myinfo、Counters、Content Rotator、Page Count等组件,用户也 uS9:cdH  
可自行编制Actiive组件,以提高系统的实用性。 ]!u12^A{  
  6. Database Access组件ADO QHt;c  
  WWW上很重要的应用是访问WEB数据库,用ASP访问WEB数据库时,必须使用ADO组件, jlmP1b9  
ADO是ASP内置的ActiveX服务器组件(ActiveX Server Component),通过在WEB服务器上 HT]v S}s  
设置ODBC和OLEDB可连接多种数据库:如SYBASE、ORACLE、INFORMIX、SQL SERVER、ACC L53qQej<  
ESS、VFP等,是对目前微软所支持的数据库进行操作的最有效和最简单直接的方法。 %X)i-^T  
  ADO组件主要提供了以下七个对象和四个集合来访问数据库。 ~s}0z&v^te  
  1) Connection对象:建立与后台数据库的连接。 b-/ztZ@u  
  2) Command对象:执行SQL指令,访问数据库。 *WSH-*0  
  3) Parameters对象和Parameters集合:为Command对象提供数据和参数。 4=j,:q  
  4) RecordSet对象:存放访问数据库后的数据信息,是最经常使用的对象。 Fq{Z-yVp  
  5) Field对象和Field集合:提供对RecordSet中当前记录的各个字段进行访问的功 )V!9/d  
能。  #RE  
  6) Property对象和Properties集合:提供有关信息,供Connection、Command、Re V#j|_N1hm  
cordSet、Field对象使用。 Gj[+{  
  7) Error对象和Errors集合:提供访问数据库时的错误信息。 Rw]4/  
  三. ASP访问数据库步骤 4_CV.?  
  在ASP中,使用ADO组件访问后台数据库,可通过以下步骤进行: /UJ@e  
  1. 定义数据源 Wvhg:vup  
  在WEB服务器上打开“控制面板”,选中“ODBC”,在“系统DSN”下选“添加”, }uI(D&?+h  
选定你希望的数据库种类、名称、位置等。本文定义“SQL SERVER”,数据源为“HT” A),nkw0X  
,数据库名称为“HTDATA”,脚本语言采用Jscript。 CYr2~0<g  
  2,使用ADO组件查询WEB数据库 G1; .\i  
  1) 调用Server.CreateObject方法取得“ADODB.Connection”的实例,再使用Open S(7_\8 h  
方法打开数据库: +]n.uA-`[a  
  conn = Server.CreateObject(“ADODB.Connection”) I91pX<NBf  
  conn.Open(“HT”) < q6z$c)K  
  2) 指定要执行的SQL命令  b>N) H  
  连接数据库后,可对数据库操作,如查询,修改,删除等,这些都是通过SQL指令来 8>: kv:MId  
完成的,如要在数据表signaltab中查询代码中含有“X”的记录 QN%w\ JXS  
  sqlStr = “select * from signaltab where code like ‘%X%’” ?/mkFDN  
  rs = conn.Execute(sqlStr) V:M$-6jv  
  3) 使用RecordSet属性和方法,并显示结果 xS~O Acxg  
  为了更精确地跟踪数据,要用RecordSet组件创建包含数据的游标,游标就是储存在 O1/U3 /2/d  
内存中的数据。 DVu_KT[Hd  
  rs = Server.CreateObject(“ADODB.RecordSet”) +O< 0q"E  
  rs.Open(sqlStr,conn,1,A) !B=Oc!e=K  
  注:A=1读取 ;WQ@dC  
  A=3 新增、修改、删除 O|#N$a&_N  
  在RecordSet组件中,常用的属性和方法有: t@GPB]3[  
  rs.Fields.Count: RecordSet对象的字段数。 A#s`!SNv  
  rs(i).Name: 第i个字段的名称,i为0至rs.Fields.Count-1 8\-Q(9q(  
  rs(i): 第i个字段的数据,i为0至rs.Fields.Count-1 IAr  
  rs(字段名): 指定字段的数据。 HaP0;9q  
  rs.Record.Count:游标中的数据记录总数。 {HV$hU+_)Q  
  rs.EOF: 是否最后一条记录。 SZOcFmC?  
  rs.MoveFirst: 指向第一条记录。 P!?Je/ Tz]  
  rs.MoveLast: 指向最后一条记录。 8S&Kf>D  
  rs.MovePrev: 指向上一条记录。 q!iMc  
  rs.MoveNext: 指向下一条记录。 L  lP  
  rs.GetRows: 将数据放入数组中。 Qm| Q0u   
  rs.Properties.Count:ADO的ResultSet或Connection的属性个数。 "K EB0U  
  rs.Properties(item).Name:ADO的ResultSet或Connection的名称。 nwwKef(  
  rs.Properties: ADO的ResultSet或Connection的值。 #+V5$  
  rs.close(): 关闭连接。 FHNK%Ko  
  4) 关闭数据库 zw{cli&S  
  conn.close() H].G%,2'  
  四.查询WEB数据库举例 UcCkn7}  
  下面这段示例程序是访问SQL SERVER数据库的 signaltab表,表中有三个字段:co s*R \!L  
de(代码字段,字符型,3位),class(分类字段,字符型,10位),memo(备注字段,字符 Zk+J=Cwq}  
型,20位)。程序中数据源DSN:HT、用户名:client、口令:passwd。 T-Od|T@[  
  屏幕输入页面input.asp {VC4rA  
   &9CKI/K:  
   x 4SI TY  
   1a#oJU  
  请输入查询条件PLEASE INPUT CONDITION By=/DVm)=  
   qyP|`Pm4  
   zy(i]6  
   2 }QD>  
   0y$aGAUm  
   sPCp20x:y8  
   9`J!]WQ1[  
    \Vis  
   BX[92~Bq  
   _VU/j9<+  
   ,}M@Am0~  
   gf]biE"k  
   ({3hX"C@Q  
  数据库处理程序shotquery.asp "7R"(.~>  
   =RR225  
   @l9qH1  
  var signalCode=Request.Form(signalCode); 0NLoqq  
  dbConn = Server.CreateObject(ADODB.Connection); _C9*M6IU  
  dbConn.open(DSN=HT;UID=client;PWD=passwd); KlgPDV9mg  
  rs = Server.CreateObject(ADODB.RecordSet); $or?7 w>  
  var sqlStr = select * from signaltab order by code; QN[-XQ>Xt  
  rs.open(sqlStr,dbConn,1); 0_Hdj K  
  if(rs.RecordCount     无符合条件记录); !F0MLvdX7^  
  Response.write(     ); ;!4Bw"Gg  
  } p*10u@,  
  else { ~Mv@Bl  
  Response.write(数据查询结果); 6KiI3%y?0  
  Response.write(代码分类备注); Xtqjx@ye  
  for(var i = 1;i +rs(code)+); fI%+  
  Response.write(+rs(class)+); *uR&d;vg.8  
  Response.write(+rs(memo)+); kJ6=T6s  
  Response.write(); n{F$,a  
  rs.MoveNext(); ~mc7O  
  } ?3!"js B  
  else break; q<>  
  } W G2 E3y  
  Response.write(); JZp*"UzQr  
  rs.close(); )^UM8 s  
  dbConn.close(); DpIv <m]  
  } OL]^4m  
   4[z a|t  
;dl>  
r}OK3J  
3Oy-\09  
转自: ASP教程采集
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水
引用

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

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

您目前还是游客,请 登录注册
欢迎提供真实交流,考虑发帖者的感受
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八