帝国软件
  设为首页 加入收藏 关于我们
 
解密帝国网站管理系统
栏 目:
 
您的位置:首页 > 技术文档 > ASP编程
ASP编写数据库维护程序
作者: 发布时间:2005-03-12 来源:
ASP(Active Server Pages)是Microsoft公司动态访问网络数据库
的最新技术,目前在Web开发中得到越来越广泛的应用。ASP编程非常灵
活,本文通过开发一个数据库维护程序,讲述一下ASP的编程方法。
开发运行环境
Oracle服务器:操作系统为UNIX,安装了Oracle8数据库。
Web服务器:奔腾586,操作系统为NT4.0,在其上安装了Web Server
IIS4.0、Oracle Net8 for Client,并创建好了和Oracle8数据库的OD
BC接口。
客户机:Win 95/98操作系统,普通浏览器(Netscape4、IE4或以
上版本),并安装开发工具Frontpage 98。
系统总体网络协议为TCP/IP。
Web服务器上ODBC的配置
首先在Web服务器Windows NT上安装访问数据库的ODBC驱动程序,
利用ODBC检测工具软件测试与数据库是否连通(运行Oracle ODBC TEST
)。连通后,在NT的控制面版中ODBC的正确配置举例如下:microsoft
odbc for oracle安装 数据源名称(即odbc的名字) infosystem 描
述(d) 信息 oracle用户名称(u) user—name oracle用户密码 use
r—passwd 服务器(s) ora8
编写源代码
数据库的维护包括增加、删除、修改、保存和查询操作。下边这段
程序是对Oracle用户为user—name(密码为user—passwd)中的表tab
—code(编码库)进行维护,tab—code有两个字段,即bm(编码字段,
字符型,5位)和mc(名称字段,字符型,20位)。
1.与数据库连接,定义子例程:
<%'赋初值%>
<% mc=Request("mc") %>
<%'连接源数据库%>
<%
Set Conn=Server.CreateObject("ADODB.Connection")
Conn.Open "infosystem","user—name","user—passwd"
'参数的含义见上表
set bmrs = Conn.Execute("SELECT bm FROM bmb where mc=' "&m
c&" ' ")
temp1 = bmrs("bm")
sql—1 = request("sql—1")
if sql—1 = " " then
sql—1="SELECT bm,mc FROM table—code WHERE bm like ' " &
temp1 & "%' order by bm"
end if
Call treat()
%>
<%
Sub Reset()
bm = " "
temp2 = " "
End Sub
%>
<%
Call Reset()
num—recn = Conn.Execute("SELECT Max(bm) FROM table—code
WHERE bm like ' " & temp1 & "%' ")
%>
<%
Sub treat()
Set num—recn = Conn.Execute(sql—1)
if num—recn.eof then
else
sum—recn = 0
Do While Not num—recn.EOF
num—recn.MoveNext
sum—recn = sum—recn+1
Loop
if sum—recn <> 0 then
sele—recn=sum—recn
num—recn.MoveFirst
num—recn.Move(sum—recn-1)
Call extract()
end if
end if
End Sub
%>
<%
Sub extract()
bm = num—recn("bm")
temp2 = num—recn(1)
num—recn.Close
End Sub
%>
2.增加一条记录:
<%
sum—recn =sum—recn + 1
bm = Request("bm")
temp2 = Request("temp2")
Insertsql = "INSERT INTO table—code(bm,mc) VALUES (' " &
bm & " ',' " & temp2 & " ')"
Set Insertrs = Conn.Execute(Insertsql)
%>
3.删除当前记录:
<%bm = Request("bm")
set delrs = Conn.Execute("Delete From table—code where bm
=' " & bm &" ' ")
Call treat()
%>
4.更新当前记录后入库(提交更新过的记录):
<%
bm = Request("bm")
temp2 = Request("temp2")
UpdateSQL = "UPDATE table—code SET mc=' " & temp2 & " ' w
here bm=' " & bm &" ' "
Set UpdateRS=Conn.Execute(UpdateSQL)
%>
5.设置查询条件(内容),输出查询结果:
<%
Call Reset()
temp2 = Request("temp2")
sql—1="SELECT bm,mc FROM table—code WHERE mc like ' " &
temp2 & "%' order by bm"
call treat()
%>
'到第一条记录
<%
Set num—recn = Conn.Execute(sql—1)
sum—recn = Request("sum—recn")
sele—recn=1
Call extract()
%>
<%
'查找前一条记录
Set num—recn = Conn.Execute(sql—1)
sele—recn = Request("sele—recn")
sum—recn = Request("sum—recn")
if sele—recn >1 then
sele—recn = sele—recn-1
num—recn.Move(sele—recn-1)
end if
Call extract()
%>
<%
'查找下一条记录
Set num—recn = Conn.Execute(sql—1)
sele—recn = Request("sele—recn")
sum—recn = Request("sum—recn")
if CInt(sele—recn) < CInt(sum—recn) then
sele—recn=sele—recn+1
num—recn.Move(sele—recn-1)
else
num—recn.MoveFirst
num—recn.Move(sum—recn-1)
end if
Call extract()
%>
<%
'到最后一条记录
Call treat()
%>
开发过程中遇到的问题及解决方法
1.用Frontpage98配合ASP技术的开发模式,虽然不是很标准,但是
编程效率高,而且简单易行。而用Studio6.0中的INTER DEV进行编程,
应该是最标准的,但其编程复杂,维护难度大。
为了提高效率和保持代码的正确性,我们可用记事本打开ASP程序
,将部分代码输入或粘贴上去,从而避免程序代码的丢失或篡改。
2.有时ASP程序访问数据库时,如果遇到网络瓶颈等因素,速度会
变慢,此时往往会返回“运行超时”的错误,解决此问题的方法是,将
延时时间设得足够大,如:
<%server.scripttimeout=10000%> 
  
评论】【加入收藏夹】【 】【打印】【关闭
※ 相关链接
 ·浅谈asp编程中的测试打印、有效性  (2005-03-12)
 ·用ASP编写网络传呼机  (2005-03-12)
 ·ASP编程中15个非常有用的例子(一  (2005-03-12)
 ·ASP编程中15个非常有用的例子 (  (2005-03-12)
 ·ASP编写完整的一个IP所在地搜索类  (2005-03-12)
 ·用ASP编程控制在IIS建立Web站点  (2005-03-12)

   栏目导行
  PHP编程
  ASP编程
  ASP.NET编程
  JAVA编程
   站点最新
·致合作伙伴的欢迎信
·媒体报道
·帝国软件合作伙伴计划协议
·DiscuzX2.5会员整合通行证发布
·帝国CMS 7.0版本功能建议收集
·帝国网站管理系统2012年授权购买说
·PHPWind8.7会员整合通行证发布
·[官方插件]帝国CMS-访问统计插件
·[官方插件]帝国CMS-sitemap插件
·[官方插件]帝国CMS内容页评论AJAX分
   类别最新
·在ASP中使用数据库
·使用ASP脚本技术
·通过启动脚本来感受ASP的力量
·学习使用ASP对象和组件
·解析asp的脚本语言
·初看ASP-针对初学者
·ASP开发10条经验总结
·ASP之对象总结
·ASP与数据库应用(给初学者)
·关于学习ASP和编程的28个观点
 
关于帝国 | 广告服务 | 联系我们 | 程序开发 | 网站地图 | 留言板 帝国网站管理系统