文章探索:   分类:    关键字:  
  + 栏目导航
  + 相关文章
asp中有关字符编码转换的几个函数
绝妙的asp生成静态页面html函数
Asp计算页面执行时间
一个简单的用存储过程分页
将asp页面转换成htm页面
ASP网站漏洞解析及黑客入侵防范方法
URL编码与SQL注入
几种常用排序算法(asp)
ASP调用带参数存储过程的几种方式
实用的ASP连接数据库的函数
ASP如何获取真实IP地址
ASP中怎么实现SQL数据库备份、恢复
判断Cookies是否处于开启状态
怎样才能将服务器端文件夹下的文件,..
几行Asp代码实现防止表单重复提交
用ASP设计网站在线人数统计程序
asp论坛在线人数统计研究
如何用ASP远程在数据库中创建Table
用ASP调用SQL Server的视图和存储过程
Asp与XML的关系
ASP读取EXCEL
在ASP中使用Oracle数据库技巧
一个通过web.Mail发送邮件的类
几种打开记录集方式的比较
购物车范例(购物车页面 )
如何使用FSO搜索硬盘文件
GB码和BIG5码的互换技术
用ASP开发WEB日期选择器
一个投票系统的源程序(coveryourasp.c..
列出服务器上的打印机


技术教程 -> ASP教程 ->  
在ASP中使用Oracle数据库技巧
来源:转载   人气:1783   录入时间:2007-11-8
    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.com 111 John White 888-888-8888 johnw@yahoo.com 101 Don Wod 416-333-3344 donwod@test.com
   
     数据的访问和存取
   
     1) Instantiate OO4O Object, OraSession and interface OraDatabase for connecting to ORACLE.   
     
     初始化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>
   
   
     <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数据库是二种比较流行的技术,都有相当广泛的用户群,如果能够有机地将二者结合起来,将能够给工作带来许多方便,希望这篇文章能够起到抛砖引玉的作用,使读者能够更好地探索将这二种技术结合使用的途径。




Copyright(C)2007-2024 广州市佳沛数码科技有限公司 版权所有
公司地址: 广州市荔湾区东漖北路560号511室
电话:020-81803473 传真:020-81544987