在ASP中使用Oracle数据库技巧

时间:2008-05-17 11:47:00 

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 
     %> 

标签:Oracle,数据库,asp
0
投稿

猜你喜欢

  • asp sqlserver 执行存储过程返回记录集报对象关闭时不允许操作

    2011-03-11 10:57:00
  • 如何从Notes中读取数据?

    2009-11-15 19:57:00
  • asp如何在约定时间显示特定的提示信息?

    2010-06-28 16:52:00
  • CSS注意事项: 针对 Safari(WebKit)

    2008-10-29 11:57:00
  • 使用 XML HTTP Request 对象[翻译]

    2007-11-07 21:11:00
  • Asp Object 之:AddHeader

    2008-05-05 12:58:00
  • Case和If哪个更好用?

    2009-10-28 18:25:00
  • 用Asp修改注册表

    2008-01-04 12:33:00
  • 如何使用Iframe实现本页提交?

    2010-06-05 12:36:00
  • asp中获取当前页面的地址与参数的函数代码

    2011-02-20 10:37:00
  • 一个简单的北京2008奥运倒计时代码

    2008-03-16 14:15:00
  • DW中如何使用Library

    2007-02-03 11:39:00
  • Dreamweaver使用技巧之如何巧用DW4文件库更新网站

    2010-10-20 20:07:00
  • 教你怎样在Oracle数据库中高速导出/导入

    2009-02-04 16:59:00
  • 设计高效的faq页面

    2011-06-10 13:13:00
  • ASP ,IP地址分段计算

    2008-04-13 06:55:00
  • 轻松掌握怎样从Windows命令行启动MySQL

    2009-02-23 17:18:00
  • 用ASP实现txt,doc,jpg等文件下载的函数

    2007-08-17 13:17:00
  • 47个惊人的CSS3动画演示

    2010-02-07 12:32:00
  • javascript的正则表达式

    2010-07-27 12:29:00
  • asp之家 网络编程 m.aspxhome.com