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