程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> Visual Basic語言 >> VB綜合教程 >> 實現Access數據庫的Web查詢

實現Access數據庫的Web查詢

編輯:VB綜合教程
ISAPI與DAO簡介
  
  ISAPI(InternetServerApplicationPrgrammingInterface)是微軟公司提供的,和其IIS緊密結合的API。用它可以編制Internet/Intranet的數據庫、網絡管理和BackOffice等應用。
  
  數據訪問對象(DAO即DataAccessObjects),原來是微軟為VisualBasic和AccessBasic設計的可編程接口。後來有了OLEAutomation(自動控制)技術,它就可以用於C++編程了。
  
  程序員可以用DAO的三種類型編制C++代碼:
  
  *DAOOLEAutomation接口;
  
  *dbDAO類;
  
  *MFCDAO類。
  
  其中dbDAO類和VisualBasic的DAO類非常相似,易於使用,筆者就是用它來進行數據庫編程。
  
  表1宏變量名FORM中對應數據域類中的屬性變量解釋
  SZTXTDATABASENAMEDATABASENAMEm—szDatabaseName數據庫名
  SZTXTTABLENAMETABLENAMEm—szTableName表名或查詢名
  SZTXTFIELDNAMEFIELDNAMEm—szFieldName搜索字段名
  SZTXTFIELDVALUEFIELDVALUEm—szFieldValue字段值
  編程背景
  
  現在有不少中小企業或部門的數據庫都基於Access,且其一般用Client/Server模式組建MIS。在當今流行Internet/Intranet且必將成為今後主流的形勢下,有必要把原先的數據庫搬上Internet/Intranet。
  
  不少人正使用ASP、IDC、VBScript、JavaScript、Perl甚至ShellScript來編制Web應用程序,雖然它們比ISAPI編制起來較容易,但其安全性較差,而且不如用C、C++等靈活強大,所以,作為一名較專業的程序員,選擇用C++等高級語言來編制Web應用是更明智的選擇。
  
  Microsoft公司的系統和開發軟件正處於流行的時候,基於上述因素,筆者用VisualC++(4.2以上)提供的ISAPI和DAO開發工具,設計了Access數據庫的通用Internet/Intranet查詢程序,可運行於IIS2.0、PeerWebServer和PersonalWebServer等Web服務器。
  
  程序使用方法和功能介紹
  
  程序編譯連接後,生成search.dll,置於Web服務器的可執行目錄中(如/cgi-bin)。
  
  Web主頁制作人員可以把以下HTML片斷插入頁面:
  
  〈formaction=″/cgi-bin/search.dll″method=″GET″〉
  
  〈inputtype=″hidden″name=″DATABASENAME″value=″Northwind.mdb″〉
  
  〈inputtype=″hidden″name=″TABLENAME″value=″產品″〉
  
  〈inputtype=″hidden″name=″FIELDNAME″value=″產品名稱″〉
  
  〈p〉〈inputtype=″text″name=″FIELDVALUE″size=″30″〉〈/p〉
  
  〈p〉〈inputtype=″submit″value=″按此查詢″〉〈/p〉
  
  〈/form〉
  
  以上三個“hidden”類型的輸入數據由主頁制作人員輸入,在浏覽器中不顯示出來,以求界面美觀,FIELDVALUE則由客戶由浏覽器填入數據。四個數據域分別解釋如下:
  
  *DATABASENAME:Access數據庫名,缺省在%system%system32目錄,如輸入全路徑名,則用C語言格式,如:c:datamydata.mdb。
  
  *TABLENAME:表名或查詢名,可以自定義一個符合輸出的查詢。
  
  *FIELDNAME:要以之為查詢條件的字段名,為文本型。
  
  *FIELDVALUE:字段值,由客戶輸入。
  
  客戶在浏覽器中輸入數據後,按下查詢按鈕,則由服務器輸出以下查詢結果:
  
  select*fromTABLENAMEwhereFIELDNAMElike″*FIELDVALUE*″
  
  因為*為Access查詢語句的通配符,所以本程序能實現基於字段FIELDNAME的模糊查詢。
  
  程序流程和主要函數說明
  
  圖1本程序對一個客戶請求的處理流程
  
  (一)頭文件MyTable.h
  
  1.定義了4個宏變量分別和FORM中的四個輸入數據域對應,用於解析參數以取得值,如表1所示。(下轉B7版)
  
  2.定義了CHttpServer類的派生類CMyTableExtension:
  
  classCMyTableExtension:publicCHttpServer
  
  {
  
  public:
  
  CStringm—stReadError;
  
  LPSTRm—szDatabaseName;
  
  LPSTRm—szTableName;
  
  LPSTRm—szFieldName;
  
  LPSTRm—szFieldValue;
  
  voidcdbSetupPage(CString&stPage);
  
  CHARatoiHex(CHARch);
  
  //ParseInput函數解析客戶輸入數據
  
  BOOLParsetInput(LPSTRszInput,LPSTRszItem,LPSTR*pszData);
  
  //strVARIANT函數把變體變量值轉換成一般數據類型值
  
  CStringstrVARIANT(constCOleVariant&var);
  
  CMyTableExtension();
  
  ~CMyTableExtension();
  
  //{{AFX—VIRTUAL(CMyTableExtension)
  
  public:
  
  virtualBOOLGetExtensionVersion(HSE—VERSION—INFO*pVer);
  
  virtualDWORDHttpExtensionProc(EXTENSION—CONTROL—BLOCK*PECB);
  
  /
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved