六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

完成Access數據庫的Web查詢

[摘要]ISAPI與DAO簡介ISAPI(InternetServerApplicationPrgrammingInterface)是微軟公司提供的,和其IIS緊密結合的API。用它可以編制Internet...

   ISAPI與DAO簡介

  ISAPI(InternetServerApplicationPrgrammingInterface)是微軟公司提供的,和其IIS緊密結合的API。用它可以編制Internet/Intranet的數據庫、網絡管理和BackOffice等應用。

  數據訪問對象(DAO即DataAccessob jects),原來是微軟為VisualBasic和AccessBasic設計的可編程接口。后來有了OLEAutomation(自動控制)技術,它就可以用于C++編程了。

  程序員可以用DAO的三種類型編制C++代碼:

  *DAOOLEAutomation接口;

  *dbDAO類;

  *MFCDAO類。

  其中dbDAO類和VisualBasic的DAO類非常相似,易于使用,筆者就是用它來進行數據庫編程。

  表1宏變量名FORM中對應數據域類中的屬性變量解釋

  SZTXTDATABASENAMEDATABASENAMEm—szDatabaseName數據庫名

  SZTXTTABLENAme taBLENAMEm—szTableName表名或查詢名

  SZTXTFIELDNAMEFIELDNAMEm—szFieldName搜索字段名

  SZTXTFIELDVALUEFIELDVALUEm—szFieldValue字段值

  編程背景

  現在有不少中小企業或部門的數據庫都基于Access,且其一般用Client/Server模式組建MIS。在當今流行Internet/Intranet且必將成為今后主流的形勢下,有必要把原先的數據庫搬上Internet/Intranet。

  不少人正使用ASP、IDC、vb sc ript、ja vasc ript、Perl甚至Shellsc ript來編制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″〉

  〈in puttype=″hidden″name=″DATABASENAME″value=″Northwind.mdb″〉

  〈in puttype=″hidden″name=″TABLENAME″value=″產品″〉

  〈in puttype=″hidden″name=″FIELDNAME″value=″產品名稱″〉

  〈p〉〈in puttype=″text″name=″FIELDVALUE″size=″30″〉〈/p〉

  〈p〉〈in puttype=″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);

  //Parsein put函數解析客戶輸入數據

  BOOLParsetin put(LPSTRszin put,LPSTRszItem,LPSTR*pszData);

  //strVARIANT函數把變體變量值轉換成一般數據類型值

  CStringstrVARIANT(constCOleVariant&var);

  CMyTableExtension();

  ~CMyTableExtension();

  //{{AFX—VIRTUAL(CMyTableExtension)

  public:

  virtualBOOLGetExtensionVersion(HSE—VERSION—INFO*pVer);

  virtualDWORDHttpExtensionProc(EXTENSION—CONTROL—BLOCK*PECB);


Microsoft Access在很多地方得到廣泛使用,例如小型企業,大公司的部門。




主站蜘蛛池模板: 色呦呦视频在线观看 | 婷婷色综合成人成人网小说 | 宅男噜噜噜66网站久久 | 一级成人a免费视频 | 日本人妖在线观看 | 思思久久99热免费精品6 | 色偷偷亚洲男人天堂 | 西西人体大胆77777视频 | 涩涩涩在线视频 | 午夜影院在线看 | 网站在线观看免费 | 亚洲线精品一区二区三区 | 亚洲福利一区二区 | 天天干天天做 | 青青草原1769久久免费播放 | 欧美在线综合 | 五月天婷婷伊人 | 欧美特黄a级高清免费看片 欧美特黄a级高清免费大片 | 欧美又硬又粗又长又大 | 青草影院在线观看免费版 | 香蕉视频在线观看网址 | 在线免费看污视频 | 欧美特黄一级视频 | 日韩精品成人a在线观看 | 午夜视频国语 | 色天网站| 日日日日干 | 日韩高清在线播放不卡 | 日韩在线2020专区 | 亚洲精品有码在线观看 | 日韩中文字幕在线免费观看 | 日本vs欧美一区二区三区 | 亚洲成在人线影视天堂网 | 亚洲高清在线播放 | 日韩爽爽视频爽爽 | 色图自拍偷拍 | 亚洲成年人免费网站 | 亚洲国产成人久久77 | 天天天天做夜夜夜做 | 日本一道dvd在线播放 | 欧美亚洲国产激情一区二区 |