麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

在ASP中使用Oracle數據庫

2019-11-18 20:21:16
字體:
來源:轉載
供稿:網友
  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  colinjava@hotmail.com  
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數據庫是二種比較流行的技術,都有相當廣泛的用戶群,如果能夠有機地將二者結合起來,將能夠給工作帶來許多方便,希望這篇文章能夠起到拋磚引玉的作用,使讀者能夠更好地探索將這二種技術結合使用的途徑。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成年性羞羞视频免费观看无限 | 在线成人免费观看视频 | 热久久91| 欧美视频一二三区 | 亚洲一区免费观看 | 成人男女啪啪免费观看网站四虎 | 国产在线a | 国产做爰全免费的视频黑人 | 中文字幕综合 | 亚洲国产色婷婷 | 精品久久久av | 免费视频aaa | 成人毛片网 | 久久国产精 | 国产91亚洲精品一区二区三区 | 欧美一级特黄aaaaaaa什 | 1级黄色毛片 | 羞羞视频免费网站入口 | 狠狠色噜噜狠狠狠米奇9999 | 涩涩伊人| 羞羞的动漫在线观看 | 爱福利视频 | 中文成人在线 | 久久精品免费国产 | 看免费黄色大片 | 最新欧美精品一区二区三区 | 羞羞色院91精品网站 | 成人午夜视频免费在线观看 | 国产精品99爱 | 91精品国产日韩91久久久久久360 | 中国精品久久 | 国产成年人视频 | 国产精品免费一区二区三区四区 | 一级国产航空美女毛片内谢 | 亚洲最黄视频 | 娇喘视频在线观看 | 精品国产高清一区二区三区 | 欧美亚洲一级 | 免费午夜视频 | 爱操视频| 成人mm视频在线观看 |