在ASP中使用Oracle数据库技巧

2016-01-29 18:38 8 1 收藏

在ASP中使用Oracle数据库技巧,在ASP中使用Oracle数据库技巧

【 tulaoshi.com - ASP 】

 

  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数据库中的数据。

 准备工作

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/asp/)

 我们需要什么样的环境和工具?

  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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/asp/)

  OraDynaset.Update

  ' 删除创建的对话

  Set OraSession = Noth

来源:http://www.tulaoshi.com/n/20160129/1506664.html

延伸阅读
标签: PHP
  利用OCI向数据表 'email_info' 输入数据 同上,只不过用OCI来写   相关PHP代码: if ($submit == "click"){   // The submit button was clicked!   // Get the input for fullname and email then store it in the database.   PutEnv("ORACLE_SID=ORASID"); &...
标签: PHP
  利用ORA列出全部数据表'email_info'中的数据 下面,我们将逐条读出数据库的内容,并以html表格形式显示'email_info'数据表中的数据   相关PHP代码: PutEnv("ORACLE_SID=ORASID"); $connection = Ora_Logon ("username","password"); if ($connection == false){   echo O...
标签: PHP
  利用OCI列出全部数据表'email_info'中的数据 同上,只不过用OCI来写   相关PHP代码: PutEnv("ORACLE_SID=ORASID"); $connection = OCILogon ("username","password"); if ($connection == false){   echo OCIError($connection)." ";   exit; } ...
在C++ Builder中使用Access数据库既可以在设计期实现,也可以在运行期通过编程实现。下面就以一个简单的例子,来说明在C++ Builder中如何使用Access数据库。 在设计期使用Access数据库 首先新建一个工程,保存单元文件为Unit1.cpp,保存工程文件为Project1.bpr。假设保存工程文件的路径下已有一个Access数据库文件student.mdb,...
标签: ASP
用ASP操作数据库时,很多人都使用记录集,但我觉得用SQL语句更好些,于是就写了这篇文章,希望对你有帮助。 <% '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' '以下段为连接数据库和断开连接(数据库为Access格式,采用DSN来连接) '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' sub c...

经验教程

725

收藏

76
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部