asp连oracle源码,asp连接 Oracle

Oracle是世界上用得最多的数据库之一,活动服务器网页(ASP)是一种被广泛用于创建动态网页的功能强大的服务器端脚本语言。许多ASP开发人员一直在考虑,能否在开发互联网应用、电子商务网站、互联网管理系统时结合使用ASP和Oracle数据库?这个问题的答案是肯定的,我们还可以使用VB访问 Oracle数据库。在本篇文章中,我们将主要讨论如何使用ASP来处理Oracle数据库中数据的方法。   在开始讨论这个问题前,我们需要了解几个背景知识,Oracle Objects for OLE就是其中之一。Oracle Objects for OLE是Oracle开发的一个中间件,它允许使用微软的OLE标准的客户端应用程序访问Oracle的数据库。也许会有读者说,我们也可以使用ODBC 访问Oracle的数据库。当然,可以使用ODBC访问Oracle数据库,但我认为,Oracle Objects for OLE比ODBC更安全,而且完全支持PL/SQL。PL/SQL是Oracle对SQL命令集的扩展,开发人员能够利用它对非结构化的SQL命令块进行流控制和逻辑设计。如果安装的是Oracle8i数据库,我相信你已经在使用Oracle Objects for OLE。如果还没有使用Oracle Objects for OLE,可以从Oracle的网站上下载它。   另外,我们还需要了解Oracle针对Visual Basic开发的二个对象和一个接口:OraSession、OraDynaset对象和OraDatabase接口。OraSession对象管理应用程序的OraDatabase、OraConnection和OraDynaset,它是由ASP的CreateObject而不是Oracle Objects for OLE创建的一个对象。OraDatabase接口向Oracle数据库表示表现用户对话,并为SQL、PL/SQL的执行提供方法。它们每个都有一些属性和方法。例如,OraDynaset对象有BOF、EOF、Bookmark、Connection等属性以及AddNew、Update、 Delete、Edit、Refresh、Clone等10个方法。   下面我们就开始切入主题,讨论如何使用ASP处理Oracle数据库中的数据。    准备工作   我们需要什么样的环境和工具?   1)我使用了Oracle8i、IIS5.0、Windows2000专业版作为应用程序的开发和运行环境。   2)在Oracle数据库中建立一个名字为MYTABLE1或类似的表。 ID (type: number) User Name(type: varchar2) Phone(type: varchar2) Email(type: varchar2)100 Colin Tong 999-999-8888 colinjava@hotmail.com111 John White 888-888-8888 johnw@yahoo.com101 Don Wod 416-333-3344 donwod@test.com数据的访问和存取    1) Instantiate OO4O Object, OraSession and interface OraDatabase for connecting to ORACLE.    1)初始化Oracle Objects for OLE、OraSession对象和OraDatabase接口,为连接ORACLE数据库作准备。   首先,使用CreateObject创建OraSession对象,然后通过打开一个与Oracle的连接创建OraDatabase对象,如下所示:<% Set OraSession = CreateObject("OracleInProcServer.XOraSession") Set OraDatabase = OraSession.OpenDatabase("", _ "username/password", Cint(0)) %>   “username”和“password”是你所使用的关系数据库的用户名和口令。    2)创建OraDynaset对象执行SQL命令。我们可以使用CreateDynaset或DbCreateDynaset创建记录集。<% 'execute SQL Set OraDynaset = OraDatabase.DbCreateDynaset( _ "select * from mytable1", cint(0)) %>  3)存取数据并删除创建的对象。 <% Do While(OraDynaset.EOF = FALSE) Response.write(OraDynaset.Fields("ID")) Response.write(OraDynaset.Fields("UserName")) ... others ... ... ... OraDynaset.MoveNext Loop 'remove OraSession Set OraSession = Nothing %>   编辑数据记录    我们将使用OraDynaset的方法实现对数据记录的编辑。    1)使用SQL语句创建OraDynaset对象。<% '创建ID= fID的记录的OraDynaset对象。 Set OraDynaset = OraDatabase.CreateDynaset(_ "select * from MYTABLE1 where ID= "& fID, cint(0)) %>  fID是想插入更更新的记录的ID值。    2)执行OraDynaset更新或添加数据记录。 <% '使用Edit方法更新ID=fID记录的域。 '或使用AddNew插入一个新记录 OraDynaset.Edit OraDynaset.Fields("Phone").Value = fPhone OraDynaset.Update ' 删除创建的对话 Set OraSession = Nothing %>删除数据记录    如果已经真正地理解了我们在上面讨论的一些方法(Edit、Update和AddNew),也许有的读者已经知道该如何在Oracle数据库中删除记录了。 <% '删除所有符合上面条件的记录 OraDynaset.Delete %>  在Oracle8i中搜索和更新数据记录的代码  1)搜索<% 'RetriveRecProc.asp -使用ASP的Oracle Objects for OLE更新数据记录%> <% '定义作为OLE对象的变量 Dim OraSession Dim OraDatabase Dim OraDynaset'创建OraSession对象 Set OraSession = CreateObject("OracleInProcServer.XOraSession")'通过打开Oracle数据库的一个连接创建OraDatabase对象 '一定要使用自己的用户名和口令访问Oracle数据库 Set OraDatabase = OraSession.OpenDatabase("", "user/password", _ Cint(0)) '创建OraDynaset对象执行SQL语句 Set OraDynaset = OraDatabase.DbCreateDynaset(_ "select * from mytable1", cint(0)) %> <html><body> <H3>Retrieve All Records in MYTABLE1 Table ( in Oracle) Using oo4o</H3> <table border=1 ID="Table1"> <% Do While(OraDynaset.EOF = FALSE) Response.Write("<tr><td>") Response.write(OraDynaset.Fields("ID")) Response.Write("</td><td>") Response.write(OraDynaset.Fields("UserName")) Response.Write("</td><td>") Response.write(OraDynaset.Fields("Phone")) Response.Write("</td><td>") Response.write(OraDynaset.Fields("Email")) Response.Write("</td></tr>") OraDynaset.MoveNext Loop '删除OraSession Set OraSession = Nothing %> </table> <a href="javascript:window.history.go(-1)"> Back previous Page</a> | <a href="index.html"> Back home Page</a> </body></html>  2)更新<% 'UpdateRecProc.asp -使用ASP的Oracle Objects for OLE更新数据记录 %> <% '定义作为OLE对象的变量。 Dim OraSession Dim OraDatabase Dim OraDynaset '从提交的表格中获取字段值 fID = request.form("ID") fUserName = request.form("UserName") fPhone = request.form("Phone") fEmail = request.form("Email") '创建OraSession对象 Set OraSession = CreateObject("OracleInProcServer.XOraSession") '通过打开Oracle数据库的一个连接创建OraDatabase对象 Set OraDatabase = OraSession.OpenDatabase("", "user/password", _ Cint(0)) '创建ID= fID的记录的OraDynaset对象 Set OraDynaset = OraDatabase.CreateDynaset(_ "select * from MYTABLE1 where ID= "& fID, cint(0)) '使用Edit方法更新ID=fID记录的字段 Do While(OraDynaset.EOF = FALSE) OraDynaset.Edit OraDynaset.Fields("UserName").Value = fUserName OraDynaset.Fields("Phone").Value = fPhone OraDynaset.Fields("Email").Value = fEmail OraDynaset.Update OraDynaset.MoveNext Loop %> <html><body> <H3>Update A Record in MYTABLE1 Table (Oracle) Using oo4o</H3> The record (ID=<%=fID%>) has been updated successfully!<br> You can view the result <a href="RetrieveAllRec.asp"> here</a> <p> <a href="javascript:window.history.go(-1)"> Back previous Page</a> &bnsp;&bnsp; <a href="javascript:window.history.go(-2)"> Back home Page</a> <% '删除OraSession对象 Set OraSession = Nothing %> </body荆?html>  至此,我们已经讨论了如何在ASP代码中使用Oracle Objects for OLE来处理Oracle数据库中的数据。    使用 存储过程   我们已经讨论了如何在ASP中访问Oracle数据库,所有的SQL语句都可以嵌入在ASP网页中。如果在ASP中使用存储过程,将更能够更有效地处理数据。我建议读者除在ASP中嵌入SQL语句外,还应当使用PL/SQL存储过程。在Oracle数据库中创建存储过程已经超出了本文章的范围,在这里就不再进行介绍了。    ASP和Oracle数据库是二种比较流行的技术,都有相当广泛的用户群,如果能够有机地将二者结合起来,将能够给工作带来许多方便,希望这篇文章能够起到抛砖引玉的作用,使读者能够更好地探索将这二种技术结合使用的途径。二.0 then response.write "错误 :" & err.description & "" response.end end if end sub sub enddb() set objoradb = nothing set objorasession = nothing end sub function gettablelist(str) dim strsql,strtmp dim objrs strsql = "select at.table_name as tname,au.username as uname from all_tables at,all_users au where au.username=at.owner order by au.username" set objrs = objoradb.dbcreatedynaset(strsql,0) while not objrs.eof stra = objrs("uname") & "." & objrs("tname") if str=stra then strtmp = strtmp & "" & stra & "" else strtmp = strtmp & "" & stra & "" end if objrs.movenext wend set objrs = nothing gettablelist = strtmp end function %>

all tables : ()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值