麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數(shù)據(jù)庫 > Access > 正文

實(shí)現(xiàn)Access數(shù)據(jù)庫的Web查詢

2024-09-07 19:04:30
字體:
供稿:網(wǎng)友

   ISAPI與DAO簡(jiǎn)介

  ISAPI(InternetServerApplicationPrgrammingInterface)是微軟公司提供的,和其IIS緊密結(jié)合的API。用它可以編制Internet/Intranet的數(shù)據(jù)庫、網(wǎng)絡(luò)管理和BackOffice等應(yīng)用。

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

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

  *DAOOLEAutomation接口;

  *dbDAO類;

  *MFCDAO類。

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

  表1宏變量名FORM中對(duì)應(yīng)數(shù)據(jù)域類中的屬性變量解釋

  SZTXTDATABASENAMEDATABASENAMEm—szDatabaseName數(shù)據(jù)庫名

  SZTXTTABLENAme taBLENAMEm—szTableName表名或查詢名

  SZTXTFIELDNAMEFIELDNAMEm—szFieldName搜索字段名

  SZTXTFIELDVALUEFIELDVALUEm—szFieldValue字段值

  編程背景

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

  不少人正使用ASP、IDC、vb sc ript、ja vasc ript、Perl甚至Shellsc ript來編制Web應(yīng)用程序,雖然它們比ISAPI編制起來較容易,但其安全性較差,而且不如用C、C++等靈活強(qiáng)大,所以,作為一名較專業(yè)的程序員,選擇用C++等高級(jí)語言來編制Web應(yīng)用是更明智的選擇。

  Microsoft公司的系統(tǒng)和開發(fā)軟件正處于流行的時(shí)候,基于上述因素,筆者用VisualC++(4.2以上)提供的ISAPI和DAO開發(fā)工具,設(shè)計(jì)了Access數(shù)據(jù)庫的通用Internet/Intranet查詢程序,可運(yùn)行于IIS2.0、PeerWebServer和PersonalWebServer等Web服務(wù)器。

  程序使用方法和功能介紹

  程序編譯連接后,生成search.dll,置于Web服務(wù)器的可執(zhí)行目錄中(如/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=″產(chǎn)品″〉

  〈in puttype=″hidden″name=″FIELDNAME″value=″產(chǎn)品名稱″〉

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

  〈p〉〈in puttype=″submit″value=″按此查詢″〉〈/p〉

  〈/form〉

  以上三個(gè)“hidden”類型的輸入數(shù)據(jù)由主頁制作人員輸入,在瀏覽器中不顯示出來,以求界面美觀,F(xiàn)IELDVALUE則由客戶由瀏覽器填入數(shù)據(jù)。四個(gè)數(shù)據(jù)域分別解釋如下:

  *DATABASENAME:Access數(shù)據(jù)庫名,缺省在%system%system32目錄,如輸入全路徑名,則用C語言格式,如:c:datamydata.mdb。

  *TABLENAME:表名或查詢名,可以自定義一個(gè)符合輸出的查詢。

  *FIELDNAME:要以之為查詢條件的字段名,為文本型。

  *FIELDVALUE:字段值,由客戶輸入。

  客戶在瀏覽器中輸入數(shù)據(jù)后,按下查詢按鈕,則由服務(wù)器輸出以下查詢結(jié)果:

  select*fromTABLENAMEwhereFIELDNAMElike″*FIELDVALUE*″

  因?yàn)?為Access查詢語句的通配符,所以本程序能實(shí)現(xiàn)基于字段FIELDNAME的模糊查詢。

  程序流程和主要函數(shù)說明

  圖1本程序?qū)σ粋€(gè)客戶請(qǐng)求的處理流程

  (一)頭文件MyTable.h

  1.定義了4個(gè)宏變量分別和FORM中的四個(gè)輸入數(shù)據(jù)域?qū)?yīng),用于解析參數(shù)以取得值,如表1所示。(下轉(zhuǎn)B7版)

  2.定義了CHttpServer類的派生類CMyTableExtension:

  classCMyTableExtension:publicCHttpServer

  {

  public:

  CStringm—stReadError;

  LPSTRm—szDatabaseName;

  LPSTRm—szTableName;

  LPSTRm—szFieldName;

  LPSTRm—szFieldValue;

  voidcdbSetupPage(CString&stPage);

  CHARatoiHex(CHARch);

  //Parsein put函數(shù)解析客戶輸入數(shù)據(jù)

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

  //strVARIANT函數(shù)把變體變量值轉(zhuǎn)換成一般數(shù)據(jù)類型值

  CStringstrVARIANT(constCOleVariant&var);

  CMyTableExtension();

  ~CMyTableExtension();

  //{{AFX—VIRTUAL(CMyTableExtension)

  public:

  virtualBOOLGetExtensionVersion(HSE—VERSION—INFO*pVer);

  virtualDWORDHttpExtensionProc(EXTENSION—CONTROL—BLOCK*PECB);

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产免费人做人爱午夜视频 | 欧美黄色大片免费观看 | 成人午夜高清 | 久草成人在线观看 | 欧美 日韩 中文 | 极品国产91在线网站 | 欧美一级淫片免费视频1 | 久久久久久免费 | 久久精品亚洲一区 | 国产精品www | 国产又粗又爽又深的免费视频 | 欧洲精品久久 | 色99久久 | 少妇一级淫片免费放4p | 九九福利视频 | 日本一区二区免费在线观看 | bt 自拍 另类 综合 欧美 | 色就色 综合偷拍区91网 | 久久最新免费视频 | 欧美日本一 | 国产精品久久久久久久久久久久久久久 | 久久最新免费视频 | 日本在线看 | 看免费毛片 | 国产精品亚洲一区二区三区久久 | 欧美另类视频在线 | av老司机久久 | 欧美一级不卡视频 | 一级免费特黄视频 | 欧美国产成人在线 | 欧美一级电影网 | 一级毛片大片 | 91小视频在线观看免费版高清 | 久色视频网站 | 亚洲最大的成人网 | 亚洲精品 在线播放 | 久久日韩在线 | 色中色综合 | 情侣啪啪网站 | 精品国产一区二区久久 | 12av电影 |