國(guó)家工信部網(wǎng)站備案實(shí)名:湖北自考網(wǎng) 為考生提供湖北自考信息服務(wù),僅供學(xué)習(xí)交流使用,官方信息以湖北教育考試院為準(zhǔn)。

湖北自考網(wǎng)

網(wǎng)站首頁(yè) 自考專(zhuān)業(yè) 自考院校 考場(chǎng)查詢 成績(jī)查詢 網(wǎng)上報(bào)名 考生平臺(tái)
專(zhuān)題:
自考報(bào)名時(shí)間 考試時(shí)間 自考單科網(wǎng)課 模擬考試 教材大綱 免考辦理 轉(zhuǎn)考辦理 實(shí)踐考核 畢業(yè)申請(qǐng) 學(xué)位英語(yǔ)培訓(xùn) 學(xué)位申請(qǐng) 專(zhuān)升本 成人高考 中專(zhuān)
湖北自考在線 湖北學(xué)位英語(yǔ)培訓(xùn)班 湖北成人高考報(bào)名 湖北自考視頻免費(fèi)領(lǐng)取
當(dāng)前位置:湖北自考網(wǎng) > 基于Web的交互式數(shù)據(jù)庫(kù)查詢技術(shù)

基于Web的交互式數(shù)據(jù)庫(kù)查詢技術(shù)

湖北自考網(wǎng) 來(lái)源: 時(shí)間:2005-11-09 00:00:00
基于Web的交互式數(shù)據(jù)庫(kù)查詢技術(shù)

中國(guó)科學(xué)技術(shù)大學(xué)計(jì)算機(jī)系  唐雪峰 趙保華

摘要: 介紹通過(guò)Web服務(wù)器實(shí)現(xiàn)數(shù)據(jù)庫(kù)動(dòng)態(tài)數(shù)據(jù)交互的幾種方法及其對(duì)比,著重以實(shí)例說(shuō)明如何實(shí)現(xiàn)與DBASE x和ORACLE數(shù)據(jù)庫(kù)的交互操作。

關(guān)鍵詞:Web, CGI,ISAPI,ASP

1 概述

Web技術(shù)是一項(xiàng)很新的技術(shù),它不僅為Internet的廣泛普及起到關(guān)鍵性的作用,而且還在其他相關(guān)計(jì)算機(jī)網(wǎng)絡(luò)應(yīng)用技術(shù)發(fā)展中起到關(guān)鍵作用,例如Intranet、電子商務(wù)等,目前它已成為計(jì)算機(jī)網(wǎng)絡(luò)應(yīng)用的一個(gè)主要技術(shù),尤其重要的技術(shù)是web動(dòng)態(tài)技術(shù),與后臺(tái)數(shù)據(jù)庫(kù)的交互式動(dòng)態(tài)查詢技術(shù)。本文針對(duì)常用的web動(dòng)態(tài)技術(shù),與數(shù)據(jù)庫(kù)交互技術(shù)作以介紹。

2 實(shí)現(xiàn)Web動(dòng)態(tài)技術(shù)的幾種方法

2.1 利用CGI實(shí)現(xiàn)Web動(dòng)態(tài)技術(shù)

在Web應(yīng)用中,與其他動(dòng)態(tài)編程技術(shù)相比,CGI技術(shù)雖然是一項(xiàng)很早期的技術(shù),有很多的不足,性能差、需要大量的HTTP知識(shí)、不靈活等等,但筆者認(rèn)為它還是具有很強(qiáng)的使用性,因?yàn)槠涫褂闷毡?,很多Web服務(wù)器均支持。就其協(xié)議而言,具有簡(jiǎn)單、易掌握,見(jiàn)效快等特點(diǎn)。因此本文介紹的應(yīng)用實(shí)例主要是基于它的。

CGI是Common Gateway Interface的縮寫(xiě),目前大多數(shù)的Web產(chǎn)品提供此項(xiàng)服務(wù)功能,它可以使用任何一種計(jì)算機(jī)語(yǔ)言編寫(xiě),使用尤其廣泛的有C、Perl、C++語(yǔ)言,在Internet上有很多相關(guān)的資料和程序及源代碼。

它的運(yùn)行過(guò)程如圖1,Web服務(wù)器接受客戶端瀏覽器的URL請(qǐng)求,找到CGI程序后,啟動(dòng)并產(chǎn)生一個(gè)CGI進(jìn)程,將系統(tǒng)參數(shù)和用戶請(qǐng)求參數(shù)交給CGI進(jìn)程,由CGI進(jìn)程提取數(shù)據(jù)庫(kù)中數(shù)據(jù)處理后,產(chǎn)生結(jié)果,反饋給Web服務(wù)器,由其反饋給用戶端瀏覽器。這樣完成了一個(gè)請(qǐng)求過(guò)程。

圖1 CGI調(diào)用流程(略)

IDC(Internet數(shù)據(jù)庫(kù)連接器)
通過(guò)使用Internet數(shù)據(jù)庫(kù)連接器可以發(fā)布你的數(shù)據(jù)庫(kù),允許用戶訪問(wèn)數(shù)據(jù),只需開(kāi)發(fā)者編寫(xiě)最少量的代碼。你只需提供SQL查詢(IDC將在數(shù)據(jù)庫(kù)上執(zhí)行它)和模板(描述數(shù)據(jù)顯示和收集的方式),而不用進(jìn)行復(fù)雜的程序設(shè)計(jì),這種方法適用于簡(jiǎn)單的不需要控制和驗(yàn)證數(shù)據(jù)的程序。它是IIS的功能之一 ,IIS通過(guò)調(diào)用一個(gè)名為HTTPODBC.DLL的ISAPI應(yīng)用程序處理.IDC和.HTX文件實(shí)現(xiàn)的,調(diào)用處理過(guò)程如圖2,它是一個(gè)不連續(xù)的循環(huán)。應(yīng)用中要注意隱藏.IDC和.HTX文件。保證應(yīng)用程序和數(shù)據(jù)庫(kù)的安全性。

圖2IDC應(yīng)用程序的處理過(guò)程(略)

基于ISAPI的解決方案
ISAPI(Internet Server Application Programming Interface)是Microsoft的IIS提供的一種新的接口標(biāo)準(zhǔn),用于開(kāi)發(fā)交互式Web應(yīng)用程序,它采用的語(yǔ)言多為面向?qū)ο蟮木幊陶Z(yǔ)言如Visual C++、Delphi等,它與CGI程序很相似,但在性能方面較CGI應(yīng)用程序相比有較大提高,在執(zhí)行時(shí)不需要重復(fù)裝入代碼,能夠降低系統(tǒng)開(kāi)銷(xiāo),提高運(yùn)行速度;具有很強(qiáng)的靈活性,與服務(wù)器之間能夠很好的銜接,能夠?qū)崿F(xiàn)一些很復(fù)雜的操作和控制。分為ISAPI擴(kuò)展程序和ISAPI過(guò)濾器兩種方式,前者主要完成類(lèi)似CGI程序的功能,后者能夠?qū)崿F(xiàn)與IIS的更完美的結(jié)合,可以監(jiān)督所有的驗(yàn)證請(qǐng)求或所有服務(wù)器發(fā)送到用戶的數(shù)據(jù),過(guò)濾器跨越整個(gè)服務(wù)器,并能影響服務(wù)器的工作方式.但I(xiàn)SAPI編程需要開(kāi)發(fā)者有熟練的經(jīng)驗(yàn),特別對(duì)服務(wù)器操作、客戶端與服務(wù)器之間的通訊方式的較深的理解和嫻熟的編程技巧。

活動(dòng)服務(wù)器頁(yè)面(Active Server Pages)
它是由第三版IIS提供的新特性,實(shí)質(zhì)是通過(guò)一個(gè)名為sspifilt.dll的ISAPI過(guò)濾器實(shí)現(xiàn)的,主要提供的功能是開(kāi)發(fā)人員可以通過(guò)使用服務(wù)器端腳本(VBScript或VCScript)動(dòng)態(tài)生成網(wǎng)頁(yè),可以同訪問(wèn)數(shù)據(jù)庫(kù)的ActiveX控件連接在一起使用來(lái)實(shí)現(xiàn)數(shù)據(jù)庫(kù)的動(dòng)態(tài)交互查詢。是目前較新的一種技術(shù)。

第三方解決方案
許多第三方工具可以用來(lái)幫助你創(chuàng)建交互式Web應(yīng)用程序,它們主要改善了CGI程序的開(kāi)發(fā)環(huán)境,降低開(kāi)發(fā)人員掌握基于Web的數(shù)據(jù)庫(kù)交互式應(yīng)用程序的開(kāi)發(fā)難度,幫助你使用所熟悉環(huán)境來(lái)開(kāi)發(fā)應(yīng)用程序,保存現(xiàn)有應(yīng)用程序代碼的移植和復(fù)用性。值得一提的產(chǎn)品有以下幾種產(chǎn)品:

WebAction是classTools公司的產(chǎn)品,網(wǎng)址:http://www.classtools.com/

Tornado 網(wǎng)址:http://www.eudev.com/tornado.htm

WebHub是HREF Tools公司的產(chǎn)品,網(wǎng)址:http://www.href.com/

Foxweb是Fox公司的產(chǎn)品,網(wǎng)址:http://www.foxweb.com/

幾種常用方法的對(duì)比 見(jiàn)表1。

方法

名稱(chēng)

對(duì)比 項(xiàng)目

基于CGI技術(shù)數(shù)據(jù)庫(kù)連接器IDC 基于ISAPI 活動(dòng)服務(wù)器頁(yè)面ASP 第三方解決方案 操作 系統(tǒng)幾乎任何操作系統(tǒng) Window NT Window NT Window NT 與具體產(chǎn)品有關(guān) Web 服務(wù)器主流Web服務(wù)器均支持 IIS IIS IIS 與具體產(chǎn)品有關(guān) 運(yùn)行 速度每次請(qǐng)求均需要調(diào)入一次程序,隨著請(qǐng)求數(shù)量增加而變慢基于ISAPI擴(kuò)展解釋方式,速度由于其與操作系統(tǒng)和Web服務(wù)器結(jié)合緊密其速度快中一般較慢 對(duì)編程人員要求需要對(duì)HTTP、HTML、TCP\IP和CGI協(xié)議,SQL、至少一種計(jì)算機(jī)編程語(yǔ)言熟悉HTML、SQL、IDC嵌入腳本面向?qū)ο蟮木幊陶Z(yǔ)言Delphi、Visual C++,熟悉網(wǎng)絡(luò)環(huán)境和協(xié)議、數(shù)據(jù)庫(kù)接口需要熟悉HTML、Jscript或VBScripts腳本語(yǔ)言、SQL 有初步的HTML和網(wǎng)絡(luò)知識(shí)和產(chǎn)品要求的編程語(yǔ)言 培訓(xùn)對(duì)于網(wǎng)絡(luò)環(huán)境用戶較為容易容易較難較易容易 適于程序規(guī)模任何規(guī)模小特殊要求或規(guī)模性程序中小中小

表1 幾種常用方法的對(duì)比

3 實(shí)例

針對(duì)大慶采油四廠的具體情況,主要以DbaseX數(shù)據(jù)庫(kù)和Oracle數(shù)據(jù)為主,我們主要采取兩種方式,DbaseX類(lèi)型數(shù)據(jù)庫(kù)一般存放在Window NT Server上,多數(shù)編程人員多適應(yīng)Xbase語(yǔ)言的編程,我們采用第三方產(chǎn)品,在服務(wù)器端安裝Foxweb產(chǎn)品,這樣保證了現(xiàn)有軟件開(kāi)發(fā)人員能夠利用Foxpro進(jìn)行CGI程序編制達(dá)到交互目的,有助于使現(xiàn)有程序員較為容易的掌握,從而盡快產(chǎn)生良好的效果。

安裝Foxweb產(chǎn)品后,其中一個(gè)名字為Foxweb.exe的文件相當(dāng)于一個(gè)普通的CGI程序,安裝在Web服務(wù)器的CGI目錄下,用Vfoxpro編寫(xiě)的程序需要有它來(lái)解釋后執(zhí)行。

在Foxweb中提供全局變量“CGI.參數(shù)名字”和下面3個(gè)函數(shù)主要是傳遞客戶端和服務(wù)器端的一些信息和解釋、提取超文本表單的用戶請(qǐng)求數(shù)據(jù)和合并混有普通visual Foxpro程序數(shù)據(jù)變量的超文代碼,是其成為用戶能夠?yàn)g覽的信息。Foxpro程序員只需對(duì)這些有一個(gè)透徹的理解并掌握一定超文本知識(shí)就能夠進(jìn)行基于web的編程。

¡FormField():返回表單中變量的值
¡TotFields():對(duì)于多選值變量,判定變量值個(gè)數(shù)
¡MergeTxt():替換merge編碼中的<< 和 >>之間的變量
Oracle數(shù)據(jù)庫(kù)主要采用的是,服務(wù)器端直接安裝Oracle公司提供的Web服務(wù)功能,在此基礎(chǔ)上進(jìn)行二次開(kāi)發(fā),或利用Oracle產(chǎn)品的Pro*C和SQL查詢語(yǔ)言直接編寫(xiě)CGI程序來(lái)達(dá)到交互使用,或使用ODBC或JDBC數(shù)據(jù)庫(kù)接口產(chǎn)品與數(shù)據(jù)庫(kù)進(jìn)行交互式操作。

客戶端的動(dòng)態(tài)方式,一種利用HTML的表單和URL的附加查詢串向服務(wù)器的CGI程序傳遞請(qǐng)求,CGI程序?qū)?shù)據(jù)以超文本形式返回給客戶,這種方式可以通過(guò)一些嵌入的腳本語(yǔ)言來(lái)進(jìn)行表單的預(yù)處理,來(lái)減少CGI程序的負(fù)荷,提高CGI的執(zhí)行效率。另一種方式是采用JAVA Applet進(jìn)行交互,這樣可以使程序具有更好的交互性,圖形化,而且這樣由于JAVA Applet是下載到客戶端運(yùn)行的,而且JAVA Applet有很強(qiáng)的圖形處理和應(yīng)用程序接口能力,這樣CGI程序只需將基本數(shù)據(jù)提取后,返回到客戶端即可,這樣可以大大降低服務(wù)器端的負(fù)荷,將運(yùn)算量分散到客戶端,使得負(fù)荷得到均衡。

在實(shí)現(xiàn)這些內(nèi)容時(shí),數(shù)據(jù)庫(kù)的接口也是一個(gè)很重要的方面,下面列出CGI程序、ODBC、JDBC、JAVA Applet之間的數(shù)據(jù)交換簡(jiǎn)圖和基本步驟,無(wú)論如何在使用這些之前,都需要在數(shù)據(jù)庫(kù)服務(wù)器上建立相應(yīng)驅(qū)動(dòng)程序和數(shù)據(jù)源,詳細(xì)內(nèi)容請(qǐng)查閱本文后面列出的書(shū)籍。

圖3使用ODBC訪問(wèn)數(shù)據(jù)庫(kù)(略)

使用ODBC的基本步驟是:見(jiàn)圖3所示。

為ODBC分配環(huán)境句柄
分配一個(gè)連接句柄
連接到數(shù)據(jù)庫(kù)
用SQL命令分配一個(gè)語(yǔ)句句柄
傳送該語(yǔ)句
關(guān)閉連接
解除連接和環(huán)境句柄

圖4使用JDBC訪問(wèn)數(shù)據(jù)庫(kù)(略)

使用JDBC的基本步驟是:見(jiàn)圖4所示。

建立連接
創(chuàng)建Statement對(duì)象,用于執(zhí)行SQL語(yǔ)句
執(zhí)行SQL語(yǔ)句
關(guān)閉Statement對(duì)象
關(guān)閉連接

結(jié)論

本文介紹的基于Web交互式數(shù)據(jù)庫(kù)查詢技術(shù)中,基于FOXWEB CGI和基于JAVA ,ODBC針對(duì)ORACLE的CGI編程技術(shù)已廣泛應(yīng)用于大慶采油四廠生產(chǎn)開(kāi)發(fā)信息查詢系統(tǒng)中,具有很強(qiáng)的實(shí)用性。隨著新技術(shù)的不斷出現(xiàn)和編程人員對(duì)Web和網(wǎng)絡(luò)知識(shí)的了解和深入,我們可以采用更新、更好的技術(shù)的解決方案,特別是NT服務(wù)器IIS的ISAPI技術(shù)。

參考文獻(xiàn)

(1) 吳迪文, WWW數(shù)據(jù)庫(kù)系統(tǒng)信息集成技術(shù) , 微機(jī)發(fā)展,No.1,1999.

(2) 劉軍等,基于Web的交互式數(shù)據(jù)庫(kù)查詢技術(shù),微機(jī)發(fā)展,No.4,1999.

(3) 王克宏編譯,JAVA語(yǔ)言與SQL接口,清華大學(xué)出版社,1997.4

(4) 王佑中著,Web動(dòng)態(tài)技術(shù)入門(mén),機(jī)械工業(yè)出版社,1997.1.

(5) (美)Don Gaspar著,楊曉云,王建橋譯,用C++開(kāi)發(fā)Web商用程序,機(jī)械工業(yè)出版社,1998.6.

結(jié)束
本文標(biāo)簽
特別聲明:1.凡本網(wǎng)注明稿件來(lái)源為“湖北自考網(wǎng)”的,轉(zhuǎn)載必須注明“稿件來(lái)源:湖北自考網(wǎng)(m.heywebguys.com)”,違者將依法追究責(zé)任;
2.部分稿件來(lái)源于網(wǎng)絡(luò),如有不實(shí)或侵權(quán),請(qǐng)聯(lián)系我們溝通解決。最新官方信息請(qǐng)以湖北省教育考試院及各教育官網(wǎng)為準(zhǔn)!
限時(shí),免費(fèi)獲取學(xué)歷提升方案

已幫助10w萬(wàn)+意向?qū)W歷提升用戶成功上岸

  • 毛澤東思想概論

    毛澤東思想概論

    培訓(xùn)優(yōu)勢(shì):課時(shí)考點(diǎn)精講+刷題+沖刺,熟練應(yīng)對(duì)考試題型。全程督促學(xué)習(xí),安排好學(xué)習(xí)計(jì)劃。 毛澤東思想概論...自考培訓(xùn)
  • 英語(yǔ)二

    英語(yǔ)二

    本課程既是一門(mén)語(yǔ)言實(shí)踐課程,也是拓寬知識(shí)、了解世界文化的重要素質(zhì)課程,它以培養(yǎng)學(xué)習(xí)者的綜合語(yǔ)言應(yīng)用能力為目標(biāo),使他們?cè)趯W(xué)習(xí)、工作和社會(huì)交往中能夠使用英語(yǔ)進(jìn)行有效的交流。 英語(yǔ)二...自考培訓(xùn)
  • 馬克思主義基本原理概論

    馬克思主義基本原理概論

    本書(shū)包括兩個(gè)部分:自學(xué)考試大綱和基本原理。主要內(nèi)容有,馬克思主義是關(guān)于工人階級(jí)和人類(lèi)解放的科學(xué),物質(zhì)世界及其發(fā)展規(guī)律,認(rèn)識(shí)的本質(zhì)及其規(guī)律,人類(lèi)社會(huì)及其發(fā)展規(guī)律,資本主義的形成及其發(fā)展,資本主義發(fā)展的歷史進(jìn)程,社會(huì)主義社會(huì)及其進(jìn)程,共產(chǎn)主義社會(huì)及其進(jìn)程等。 馬克思主義基本原理概論...自考培訓(xùn)
  • 思想道德修養(yǎng)與法律基礎(chǔ)

    思想道德修養(yǎng)與法律基礎(chǔ)

    《思想道德修養(yǎng)與法律基礎(chǔ)》課具有鮮明的政治性、思想性、理論性、針對(duì)性、科學(xué)性、知識(shí)性以及實(shí)踐性和修養(yǎng)性。它包羅政治、思想、道德、心理本質(zhì)、學(xué)習(xí)成才和法律本質(zhì)等內(nèi)容,指導(dǎo)和回答大學(xué)生在人生、抱負(fù)、信念等方面遍及關(guān)心和迫切需要解決的問(wèn)題。 思想道德修養(yǎng)與法律基礎(chǔ)...自考培訓(xùn)
  • 中國(guó)近代史綱要

    中國(guó)近代史綱要

    “中國(guó)近現(xiàn)代史綱要”全國(guó)高等教育自學(xué)考試指定教材,依據(jù)中央審定的普通高等學(xué)?!爸袊?guó)近現(xiàn)代史綱要”編寫(xiě)大綱以及馬克思主義理論研究和建設(shè)工程重點(diǎn)教材《中國(guó)近現(xiàn)代史綱要》,結(jié)合自學(xué)考試的特點(diǎn)設(shè)計(jì)了十章,集中講述1840年鴉片戰(zhàn)爭(zhēng)爆發(fā)一直到2007年中國(guó)共產(chǎn)黨第十七次全國(guó)代表大會(huì)召開(kāi)的160多年的中國(guó)近現(xiàn)代歷史。 中國(guó)近代史綱要...自考培訓(xùn)
微信公眾號(hào) 考試交流群
湖北自考網(wǎng)微信公眾號(hào)

掃一掃關(guān)注微信公眾號(hào)

隨時(shí)獲取湖北省自考政策、通知、公告以及各類(lèi)學(xué)習(xí)資料、學(xué)習(xí)方法、課程。