在ASP中使用Oracle數(shù)據(jù)庫技巧
發(fā)表時間:2024-05-31 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]Oracle是世界上用得最多的數(shù)據(jù)庫之一,活動服務(wù)器網(wǎng)頁(ASP)是一種被廣泛用于創(chuàng)建動態(tài)網(wǎng)頁的功能強(qiáng)大的服務(wù)器端腳本語言。許多ASP開發(fā)人員一直在考慮,能否在開發(fā)互聯(lián)網(wǎng)應(yīng)用、電子商務(wù)網(wǎng)站、互聯(lián)網(wǎng)管理系統(tǒng)時結(jié)合使用ASP和Oracle數(shù)據(jù)庫?這個問題的答案是肯定的,我們還可以使用VB訪問Oracl...
Oracle是世界上用得最多的數(shù)據(jù)庫之一,活動服務(wù)器網(wǎng)頁(ASP)是一種被廣泛用于創(chuàng)建動態(tài)網(wǎng)頁的功能強(qiáng)大的服務(wù)器端腳本語言。許多ASP開發(fā)人員一直在考慮,能否在開發(fā)互聯(lián)網(wǎng)應(yīng)用、電子商務(wù)網(wǎng)站、互聯(lián)網(wǎng)管理系統(tǒng)時結(jié)合使用ASP和Oracle數(shù)據(jù)庫?這個問題的答案是肯定的,我們還可以使用VB訪問Oracle數(shù)據(jù)庫。在本篇文章中,我們將主要討論如何使用ASP來處理Oracle數(shù)據(jù)庫中數(shù)據(jù)的方法。
在開始討論這個問題前,我們需要了解幾個背景知識,Oracle Objects for OLE就是其中之一。Oracle Objects for OLE是Oracle開發(fā)的一個中間件,它允許使用微軟的OLE標(biāo)準(zhǔn)的客戶端應(yīng)用程序訪問Oracle的數(shù)據(jù)庫。也許會有讀者說,我們也可以使用ODBC訪問Oracle的數(shù)據(jù)庫。當(dāng)然,可以使用ODBC訪問Oracle數(shù)據(jù)庫,但我認(rèn)為,Oracle Objects for OLE比ODBC更安全,而且完全支持PL/SQL。PL/SQL是Oracle對SQL命令集的擴(kuò)展,開發(fā)人員能夠利用它對非結(jié)構(gòu)化的SQL命令塊進(jìn)行流控制和邏輯設(shè)計。如果安裝的是Oracle8i數(shù)據(jù)庫,我相信你已經(jīng)在使用Oracle Objects for OLE。如果還沒有使用Oracle Objects for OLE,可以從Oracle的網(wǎng)站上下載它。
另外,我們還需要了解Oracle針對Visual Basic開發(fā)的二個對象和一個接口:OraSession、OraDynaset對象和OraDatabase接口。OraSession對象管理應(yīng)用程序的OraDatabase、OraConnection和OraDynaset,它是由ASP的CreateObject而不是Oracle Objects for OLE創(chuàng)建的一個對象。OraDatabase接口向Oracle數(shù)據(jù)庫表示表現(xiàn)用戶對話,并為SQL、PL/SQL的執(zhí)行提供方法。它們每個都有一些屬性和方法。例如,OraDynaset對象有BOF、EOF、Bookmark、Connection等屬性以及AddNew、Update、Delete、Edit、Refresh、Clone等10個方法。
下面我們就開始切入主題,討論如何使用ASP處理Oracle數(shù)據(jù)庫中的數(shù)據(jù)。
準(zhǔn)備工作
我們需要什么樣的環(huán)境和工具?
1)我使用了Oracle8i、IIS5.0、Windows2000專業(yè)版作為應(yīng)用程序的開發(fā)和運行環(huán)境。
2)在Oracle數(shù)據(jù)庫中建立一個名字為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
數(shù)據(jù)的訪問和存取
1) Instantiate OO4O Object, OraSession and interface OraDatabase for connecting to ORACLE.
初始化Oracle Objects for OLE、OraSession對象和OraDatabase接口,為連接ORACLE數(shù)據(jù)庫作準(zhǔn)備。
首先,使用CreateObject創(chuàng)建OraSession對象,然后通過打開一個與Oracle的連接創(chuàng)建OraDatabase對象,如下所示:
<%
Set OraSession = CreateObject("OracleInProcServer.XOraSession")
Set OraDatabase = OraSession.OpenDatabase("", _
"username/password", Cint(0))
%>
“username”和“password”是你所使用的關(guān)系數(shù)據(jù)庫的用戶名和口令。
2)創(chuàng)建OraDynaset對象執(zhí)行SQL命令。我們可以使用CreateDynaset或DbCreateDynaset創(chuàng)建記錄集。
<%
'execute SQL Set OraDynaset = OraDatabase.DbCreateDynaset( _ "select * from
mytable1", cint(0))
%>
3)存取數(shù)據(jù)并刪除創(chuàng)建的對象。
<%
Do While(OraDynaset.EOF = FALSE)
Response.write(OraDynaset.Fields("ID"))
Response.write(OraDynaset.Fields("UserName"))
... others ...
... ...
OraDynaset.MoveNext
Loop
'remove OraSession
Set OraSession = Nothing
%>
編輯數(shù)據(jù)記錄
我們將使用OraDynaset的方法實現(xiàn)對數(shù)據(jù)記錄的編輯。
1)使用SQL語句創(chuàng)建OraDynaset對象。
<%
'創(chuàng)建ID= fID的記錄的OraDynaset對象。
Set OraDynaset = OraDatabase.CreateDynaset(_
"select * from MYTABLE1 where ID= "& fID, cint(0))
%>
fID是想插入更更新的記錄的ID值。
2)執(zhí)行OraDynaset更新或添加數(shù)據(jù)記錄。
<%
'使用Edit方法更新ID=fID記錄的域。
'或使用AddNew插入一個新記錄
OraDynaset.Edit
OraDynaset.Fields("Phone").Value = fPhone
OraDynaset.Update
' 刪除創(chuàng)建的對話
Set OraSession = Nothing
%>
刪除數(shù)據(jù)記錄
如果已經(jīng)真正地理解了我們在上面討論的一些方法(Edit、Update和AddNew),也許有的讀者已經(jīng)知道該如何在Oracle數(shù)據(jù)庫中刪除記錄了。
<%
'刪除所有符合上面條件的記錄 OraDynaset.Delete
%>
在Oracle8i中搜索和更新數(shù)據(jù)記錄的代碼
1)搜索
<%
'RetriveRecProc.asp -使用ASP的Oracle Objects for OLE更新數(shù)據(jù)記錄
%>
<% '定義作為OLE對象的變量
Dim OraSession
Dim OraDatabase
Dim OraDynaset
'創(chuàng)建OraSession對象
Set OraSession = CreateObject("OracleInProcServer.XOraSession")
'通過打開Oracle數(shù)據(jù)庫的一個連接創(chuàng)建OraDatabase對象
'一定要使用自己的用戶名和口令訪問Oracle數(shù)據(jù)庫
Set OraDatabase = OraSession.OpenDatabase("", "user/password", _
Cint(0))
'創(chuàng)建OraDynaset對象執(zhí)行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更新數(shù)據(jù)記錄
%>
<%
'定義作為OLE對象的變量。
Dim OraSession
Dim OraDatabase
Dim OraDynaset
'從提交的表格中獲取字段值
fID = request.form("ID")
fUserName = request.form("UserName")
fPhone = request.form("Phone")
fEmail = request.form("Email")
'創(chuàng)建OraSession對象
Set OraSession = CreateObject("OracleInProcServer.XOraSession")
'通過打開Oracle數(shù)據(jù)庫的一個連接創(chuàng)建OraDatabase對象
Set OraDatabase = OraSession.OpenDatabase("", "user/password", _ Cint(0))
'創(chuàng)建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>
至此,我們已經(jīng)討論了如何在ASP代碼中使用Oracle Objects for OLE來處理Oracle數(shù)據(jù)庫中的數(shù)據(jù)。
使用存儲過程
我們已經(jīng)討論了如何在ASP中訪問Oracle數(shù)據(jù)庫,所有的SQL語句都可以嵌入在ASP網(wǎng)頁中。如果在ASP中使用存儲過程,將更能夠更有效地處理數(shù)據(jù)。我建議讀者除在ASP中嵌入SQL語句外,還應(yīng)當(dāng)使用PL/SQL存儲過程。在Oracle數(shù)據(jù)庫中創(chuàng)建存儲過程已經(jīng)超出了本文章的范圍,在這里就不再進(jìn)行介紹了。
ASP和Oracle數(shù)據(jù)庫是二種比較流行的技術(shù),都有相當(dāng)廣泛的用戶群,如果能夠有機(jī)地將二者結(jié)合起來,將能夠給工作帶來許多方便,希望這篇文章能夠起到拋磚引玉的作用,使讀者能夠更好地探索將這二種技術(shù)結(jié)合使用的途徑。