自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle動態(tài)Web開發(fā)實例演示

數(shù)據(jù)庫 Oracle
Oracle動態(tài)Web的開發(fā)以及其相關(guān)的實際應(yīng)用,其中包括用Oracle WebServer來構(gòu)建Web數(shù)據(jù)庫的實際應(yīng)用 ,以及利用WebServer與PL/SQL開發(fā)動態(tài)Web實例演示。

如果你在Oracle動態(tài)Web的開發(fā)以及其相關(guān)的實際應(yīng)用的實際操作中,你對Oracle動態(tài)Web的開發(fā)以及其相關(guān)的實際應(yīng)用有不解之處時,你可以通過以下的文章對其的實際應(yīng)用與功能有所了解,以下是文章的具體介紹,望你瀏覽完以下的內(nèi)容會有所收獲。

 

1、用Oracle WebServer構(gòu)建Web數(shù)據(jù)庫應(yīng)用

Oracle 8服務(wù)器是一個完善的信息管理環(huán)境。它是一個大量數(shù)據(jù)的儲藏所,并給用戶提供對這些數(shù)據(jù)的快速訪問。它能夠支持C/S結(jié)構(gòu)進(jìn)行分布式處理和Web計算等。利用其服務(wù)器選件之一的WebServer,可以提供實現(xiàn)Web數(shù)據(jù)庫應(yīng)用的強大功能。

 

一般來說,實現(xiàn)Web數(shù)據(jù)庫應(yīng)用可以在WebServer端提供CGI/API等中間件來連接WebServer 和DB Server,也可以讓用戶通過Web瀏覽器把相關(guān)應(yīng)用下載到客戶端運行,在客戶端直接訪問數(shù)據(jù)庫,如Java Applet,Active X,Plug-in等。本文主要介紹利用Oracle 8 提供的PL/SQL和其功能強大的內(nèi)置程序包來編寫程序以實現(xiàn)動態(tài)的Web應(yīng)用。

屬于利用中間件開發(fā)的一種。中間件負(fù)責(zé)管理WebServer和DBServer之間的通信并提供應(yīng)用程序服務(wù),它能夠直接調(diào)用外部程序或腳本代碼來訪問數(shù)據(jù)庫,因此可以提供與數(shù)據(jù)庫相關(guān)的Oracle動態(tài)HTML頁面,或執(zhí)行用戶查詢,并將查詢結(jié)果格式化成HTML頁面再通過WebServer返回給用戶瀏覽器。其一般結(jié)構(gòu)如下所示:

 

Web瀏覽器 ←→ Internet ←→ Web Server ←→ CGI/API ←→ Oracle DB Server

 

2、PL/SQL

 

Oracle從其版本6開始支持一種過程處理語言PL/SQL,并將其作為所有Oracle工具的標(biāo)準(zhǔn)編程語言,從而所有的過程組件在Oracle服務(wù)器產(chǎn)品中都能實現(xiàn)。用PL/SQL可以實現(xiàn)下述重要功能:

 

存儲過程,即存放在Oracle數(shù)據(jù)庫中的程序(或代碼段)并為你的機構(gòu)完成特定的重要工作;

 

數(shù)據(jù)庫觸發(fā)器,即存放在數(shù)據(jù)庫中的代碼,可由應(yīng)用所產(chǎn)生的事件觸發(fā);

 

程序包,即把多個過程組合在一起當(dāng)作單個程序單元的代碼存放在數(shù)據(jù)庫中。

 

其中內(nèi)置程序包是預(yù)先生成的,存儲在數(shù)據(jù)庫中,且能在PL/SQL代碼塊中調(diào)用的根據(jù)需求可以傳遞參數(shù)的程序。它可以完成把結(jié)果直接輸出到終端窗口;直接從操作系統(tǒng)文件讀寫數(shù)據(jù);執(zhí)行動態(tài)的SQL等多項功能。常用的如HTP,HTF,OWA-UTIL等。下面將通過一個Oracle動態(tài)的網(wǎng)上查詢分?jǐn)?shù)的實例來說明其在動態(tài)Web中的應(yīng)用。

3、利用WebServer和PL/SQL開發(fā)動態(tài)Web實例

 

現(xiàn)有一考生成績庫需在網(wǎng)上向用戶提供查詢成績的功能。首先可考慮利用HTP程序包根據(jù)用戶輸入的考生號到數(shù)據(jù)庫中查詢相應(yīng)的信息,返回一個網(wǎng)頁。代碼如下:

 

 

  1. Create or replace procedure score_into_webpage (code_in in number)  
  2. As  
  3. cursor score_cursor is  
  4. select code,name,score  
  5. from student  
  6. where code = code_in;   
  7. Begin  
  8. Htp.htmlopen;   
  9. Htp.headopen;   
  10. Htp.title ('Student's score information');   
  11. Htp.headclose;   
  12. Htp.bodyopen (cattributes=>'bgcolor = "#80800"');   
  13. Htp.tableopen(border');   
  14. Htp.tablecaption ('Score Information','center');   
  15. Htp.tablerowopen;   
  16. Htp.tableheader (' Student Code');   
  17. Htp.tableheader (' Student Name');   
  18. Htp.tableheader (' Student Score');  

固定地顯示頁標(biāo)題、標(biāo)題、表頭等信息,每次調(diào)用此頁時顯示的信息是相同的

 

  1. Htp.tablerowclose;   
  2. For score_rec in score_cur  
  3. Loop 

利用游標(biāo)的For循環(huán)為游標(biāo)在網(wǎng)頁中產(chǎn)生一個數(shù)據(jù)行

  1. htp.tablerowopen;   
  2. htp.tabledata (score_rec.code);   
  3. htp.tabledata (score_rec.name);   
  4. htp.tabledata (score_rec.score);   
  5. htp.tablerowclose;   
  6. Endloop;   
  7. Htp.tableclose;   
  8. Htp.bodyclose;   
  9. Htp.htmlclose;   
  10. End;  

通過以上代碼,我們有了一個基本的用數(shù)據(jù)庫中的數(shù)據(jù)Oracle動態(tài)的生成一個網(wǎng)頁的方法,下面將建立一個簡單的表單。在表單中調(diào)用上述程序和接受用戶輸入的考生號碼,從而在客戶端向用戶動態(tài)地顯示從數(shù)據(jù)庫中查詢的信息。

 

  1. Create or replace procedure ScoreForm  
  2. As  
  3. Begin  
  4. Htp.headopen;   
  5. Htp.title ('Code Entry Form');   
  6. Htp.headclose;   
  7. Htp.bodyopen;   
  8. Htp.header (2,'Score Information Code Form');   
  9. Htp.p ('  
  10. ');   
  11. Htp.formopen ('Score_into_webpage',cmethod=>'GET');  

打開ScoreForm表單。缺省情況下Score_into_webpage PL/SQL過程用GET方法調(diào)用。GET方法在URL里顯示傳遞的參數(shù)。

 

  1. Htp.tableopen ('border');   
  2. Htp.tablerowopen;   
  3. Htp.tabledata ('Enter Student Code');   
  4. Htp.tabledata (htf.formtext ('code_in',5,5));  

 

用一個文本框提示用戶輸入考號。文本框的名字必須與調(diào)用過程里的輸入?yún)?shù)相同

 

 

  1. Htp.tablerowclose;   
  2. Htp.tablerowopen;   
  3. Htp.tablerowclose;   
  4. Htp.tablerowopen;   
  5. Htp.tabledata (htf.formSubmit);   
  6. Htp.tabledata (htf.formReset);   
  7. Htp.tablerowclose;   
  8. Htp.formclose;   
  9. Htp.bodyclose;   
  10. Htp.htmlclose;   
  11. End;  

上述過程在客戶端被調(diào)用后產(chǎn)生的HTML即可顯示一Oracle動態(tài)表單接受用戶輸入的考號,然后傳遞給調(diào)用的過程score_into_webpage,從而到Oracle DBServer中查詢出所需的數(shù)據(jù),再通過該過程動態(tài)生成的HTML在Web瀏覽器中顯示出來。

4、 結(jié)束語

 

作為一個大型數(shù)據(jù)庫服務(wù)器,Oracle提供了一個面向網(wǎng)絡(luò)的開發(fā)工具、應(yīng)用服務(wù)器和數(shù)據(jù)庫服務(wù)器的綜合平臺。本文利用其標(biāo)準(zhǔn)PL/SQL和內(nèi)置程序包并結(jié)合WebServer討論了基本的Oracle動態(tài)Web的開發(fā)和應(yīng)用。

 

【編輯推薦】

  1. 在Oracle 8x中實現(xiàn)自動斷開后再連接的實現(xiàn)
  2. Oracle NLS_LANG設(shè)置的具體操作方法
  3. Oracle job interval 參數(shù)設(shè)置示例
  4. 獲得Oracle權(quán)限的TABLE FUNCTION實操
  5. Oracle數(shù)據(jù)插入的性能優(yōu)化的描述

 

責(zé)任編輯:佚名 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-04-21 15:02:50

Oracle使用游標(biāo)

2010-04-20 08:53:42

Oracle左連接

2010-04-28 11:56:09

Oracle臨時表

2010-04-19 11:19:50

Oracle基本

2010-04-19 09:35:58

Oracle細(xì)粒度

2009-03-25 10:48:08

存儲銀行Oracle

2009-07-17 17:16:48

Spring iBAT

2010-05-18 09:02:55

MySQL條件查詢

2009-07-09 17:33:39

2009-08-18 10:17:25

C#枚舉類型

2010-05-27 09:38:59

MySQL Grant

2010-03-02 13:43:01

WCF事務(wù)演示

2010-04-01 13:09:12

Oracle中join

2010-04-15 16:50:58

Oracle動態(tài)SQL

2009-03-12 15:32:49

WEB開發(fā)

2010-04-20 15:16:02

Oracle實例

2012-02-23 15:36:51

IndexedDB

2011-05-10 09:26:45

BESBlackBerry

2009-11-06 15:02:47

WCF契約查詢

2009-08-26 15:35:59

C#虛函數(shù)
點贊
收藏

51CTO技術(shù)棧公眾號