亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

在ASP中使用Oracle數據庫技巧

2019-11-18 19:57:37
字體:
來源:轉載
供稿:網友

  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 johnw@yahoo.com   101 Don Wod 416-333-3344 donwod@test.com

  數據的訪問和存取

  1) Instantiate OO4O Object, OraSession and interface OraDatabase for connecting to ORACLE.      
  
  初始化Oracle Objects for OLE、OraSession對象和OraDatabase接口,為連接ORACLE數據庫作準備。

  首先,使用CreateObject創建OraSession對象,然后通過打開一個與Oracle的連接創建OraDatabase對象,如下所示:

  <% 

  Set OraSession = CreateObject("OracleIn

  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="javascr

 

  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>

 

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

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久亚洲调教| 久久精品成人欧美大片古装| 国产美女久久久| 日韩美女免费视频| 美女性感视频久久久| 成人免费在线视频网址| 日韩在线一区二区三区免费视频| 国产精品扒开腿做爽爽爽男男| 精品久久久久久久久久ntr影视| 91国偷自产一区二区三区的观看方式| 亚洲91av视频| 欧美精品videossex性护士| 午夜精品一区二区三区在线| 欧美激情视频网| 91热福利电影| 91久久久在线| 国产精品久久久久久久久久东京| 亚洲精品国产精品国自产在线| 欧美与欧洲交xxxx免费观看| 精品少妇一区二区30p| 2020国产精品视频| 欧美激情一区二区三区高清视频| 在线日韩第一页| 97免费视频在线播放| 97久久精品在线| 国产精自产拍久久久久久| 国模私拍一区二区三区| 国产免费一区二区三区在线能观看| 91久久精品国产91性色| 国产做受69高潮| 欧美在线一区二区三区四| 5566日本婷婷色中文字幕97| 欧美午夜激情小视频| 国产精品18久久久久久麻辣| 欧美大片在线看免费观看| 国产ts一区二区| 亚洲电影第1页| 亚洲欧美国内爽妇网| 伊人成人开心激情综合网| 色系列之999| 国产一区私人高清影院| 91精品免费久久久久久久久| 亚洲国产精品人人爽夜夜爽| 日韩av在线免费观看| 亚洲开心激情网| 欧美成人四级hd版| 亚洲成人激情在线观看| 久久久精品久久| 国自产精品手机在线观看视频| 黑人巨大精品欧美一区二区免费| 亚洲欧洲午夜一线一品| 国产一区二区三区日韩欧美| 日韩av最新在线| 欧美激情精品久久久久久| 国产精品99蜜臀久久不卡二区| 91精品国产91| 日韩精品视频在线观看免费| 91九色国产视频| 成人精品aaaa网站| 久久91亚洲精品中文字幕奶水| 欧美激情影音先锋| 亚洲国产成人91精品| 欧美肥老妇视频| 欧美国产亚洲视频| 日韩成人激情影院| 91沈先生在线观看| 国产视频精品一区二区三区| 日韩精品免费一线在线观看| 国产z一区二区三区| 中文字幕久精品免费视频| 热久久免费视频精品| 国产一区二区三区三区在线观看| 91中文字幕一区| 91精品国产乱码久久久久久久久| 亚洲天堂久久av| 亚洲精品久久久久久下一站| 成人免费网站在线| 久久精品视频播放| 成人性生交大片免费看小说| 国产99久久精品一区二区永久免费| 欧美日韩高清在线观看| 亚洲无av在线中文字幕| 成人午夜一级二级三级| 国产欧美欧洲在线观看| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品99导航| 欧美性xxxx极品hd欧美风情| 欧美日韩亚洲精品一区二区三区| 2019最新中文字幕| 亚洲国产精品人人爽夜夜爽| 日韩免费在线观看视频| 久久久久久高潮国产精品视| 精品久久久国产| 亚洲成人1234| 成人黄色影片在线| 久久天堂av综合合色| 午夜精品久久久久久久男人的天堂| 欧美成人一二三| 亚洲激情视频在线播放| 国产精品v日韩精品| 欧美极品美女视频网站在线观看免费| 国产成+人+综合+亚洲欧美丁香花| 国产成人亚洲综合91| 亚洲欧美国产精品va在线观看| 日韩激情av在线免费观看| 日韩最新在线视频| 久久伊人色综合| 日本精品一区二区三区在线| 欧美电影免费在线观看| 92福利视频午夜1000合集在线观看| 日韩理论片久久| 欧美精品成人在线| 久久久91精品国产| 亚洲天堂网在线观看| 亚洲一区二区三区xxx视频| 伊人久久大香线蕉av一区二区| 高清欧美性猛交xxxx| 国产一区二区三区高清在线观看| 91精品视频在线| 日韩精品欧美国产精品忘忧草| 精品国内亚洲在观看18黄| 国产精品主播视频| 亚洲老头同性xxxxx| 亚洲欧美一区二区三区在线| 丰满岳妇乱一区二区三区| 久久久91精品国产一区不卡| 国产视频精品久久久| 成人激情视频网| 国产欧美中文字幕| 国产精品va在线播放我和闺蜜| 亚洲精品午夜精品| 日韩欧美主播在线| 亚洲精品视频二区| 日本sm极度另类视频| 久久99视频精品| 久久香蕉精品香蕉| 1769国内精品视频在线播放| 国产日韩欧美电影在线观看| 亚洲japanese制服美女| 欧美精品在线视频观看| 色悠悠久久久久| 中文字幕久精品免费视频| 亚洲女性裸体视频| 欧美国产亚洲精品久久久8v| 亚洲人午夜色婷婷| 欧美国产乱视频| 久久久精品久久久| 国自产精品手机在线观看视频| 亚洲欧美日韩高清| 日韩精品久久久久| 在线观看久久av| 欧美国产中文字幕| 美女黄色丝袜一区| 欧美精品免费播放| 福利一区福利二区微拍刺激| 美女久久久久久久久久久| 日韩视频第一页| 国产亚洲精品美女久久久久| 国产精品高精视频免费| 美女久久久久久久久久久| 久久久免费高清电视剧观看| 日韩精品在线私人| 国内精品久久久久| 国产日韩欧美在线|