程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> ASP編程 >> 關於ASP編程 >> 在ASP中使用Oracle數據庫

在ASP中使用Oracle數據庫

編輯:關於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數據庫中的數據。

      准備工作

      我們需要什麼樣的環境和工具?

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

      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數據庫是二種比較流行的技術,都有相當廣泛的用戶群,如果能夠有機地將二者結合起來,將能夠給工作帶來許多方便,希望這篇文章能夠起到拋磚引玉的作用,使讀者能夠更好地探索將這二種技術結合使用的途徑。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved