萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> asp編程 >> 在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 [email protected] 111 John White 888-888-8888 [email protected] 101 Don Wod 416-333-3344 [email protected]

  數據的訪問和存取

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

copyright © 萬盛學電腦網 all rights reserved