国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

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

2019-11-18 17:48:29
字體:
來源:轉載
供稿:網友
ISAPI與DAO簡介

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

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

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

  *DAOOLEAutomation接口;

  *dbDAO類;

  *MFCDAO類。

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

表1宏變量名FORM中對應數(shù)據(jù)域類中的屬性變量解釋
SZTXTDATABASENAMEDATABASENAMEm—szDatabaseName數(shù)據(jù)庫名
SZTXTTABLENAMETABLENAMEm—szTableName表名或查詢名
SZTXTFIELDNAMEFIELDNAMEm—szFieldName搜索字段名
SZTXTFIELDVALUEFIELDVALUEm—szFieldValue字段值
  編程背景

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

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

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

  程序使用方法和功能介紹

  程序編譯連接后,生成search.dll,置于Web服務器的可執(zhí)行目錄中(如/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”類型的輸入數(shù)據(jù)由主頁制作人員輸入,在瀏覽器中不顯示出來,以求界面美觀,F(xiàn)IELDVALUE則由客戶由瀏覽器填入數(shù)據(jù)。四個數(shù)據(jù)域分別解釋如下:

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

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

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

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

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

  select*fromTABLENAMEwhereFIELDNAMElike″*FIELDVALUE*″

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

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

  圖1本程序對一個客戶請求的處理流程

  (一)頭文件MyTable.h

  1.定義了4個宏變量分別和FORM中的四個輸入數(shù)據(jù)域對應,用于解析參數(shù)以取得值,如表1所示。(下轉B7版)

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

  classCMyTableExtension:publicCHttpServer

  {

  public:

CStringm—stReadError;

LPSTRm—szDatabaseName;

LPSTRm—szTableName;

LPSTRm—szFieldName;

LPSTRm—szFieldValue;

voidcdbSetupPage(CString&stPage);

CHARatoiHex(CHARch);

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

BOOLParsetInput(LPSTRszInput,LPSTRszItem,LPSTR*pszData);

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

CStringstrVARIANT(constCOleVariant&var);

CMyTableExtension();

~CMyTableExtension();

  //{{AFX—VIRTUAL(CMyTableExtension)

  public:

  virtualBOOLGetExtensionVersion(HSE—VERSION—INFO*pVer);

  virtualDWordHttpExtensionProc(EXTENSION—CONTROL—BLOCK*PECB);

  //}}AFX—VIRTUAL

voidDefault(CHttpServerContext*pCtxt);

  DECLARE—PARSE—MAP()

  //{{AFX—MSG(CMyTableExtension)

  //}}AFX—MSG

  };

  其中定義的數(shù)據(jù)庫查詢函數(shù)(cdbSetupPage)和重構的Http服務器擴展處理函數(shù)HttpExtensionProc為其中核心。以下重點講述MyTable.cpp文件中的這兩個函數(shù)。

  (二)函數(shù)cdbSetupPage

  根據(jù)四個屬性變量(見表1)輸出數(shù)據(jù)查詢結果,存放于stPage并返回:

  1.打開數(shù)據(jù)庫OpenDatabase:

  CdbDBEnginedbeng;

  CdbDatabasedb;

  db=dbeng.OpenDatabase(m_szDatabaseName);

  2.創(chuàng)建查詢結果記錄集:

  CdbRecordsetrstMyTable;

  CStringstrQuery;

  strQuery.Format(″select*from%swhere%slike/″*%s*/″″,

  m_szTableName,

  m_szFieldName,

  m_szFieldValue);

  rstMyTable=db.OpenRecordset(strQuery,dbOpenSnapshot);

  以上strQuery為查詢語句,dbOpenSanpshot表示打開一快照類型的記錄集。

  3.用記錄集的Fields集合(Collection)的GetCount()和GetName()分別取得字段數(shù)和各字段值:

  longi;

  CStringstPage,stTemp;

  for(i=0;i〈rstMyTable.Fields.GetCount();i++){

  stTemp.Format(″〈TH〉%s〈/TH〉/n″,

rstMyTable.Fields[i].GetName());

stPage+=stTemp;}

  4.輸出記錄集中所有記錄的值:

  for(i=0;i〈rstMyTable.Fields.GetCount();i++){

stTemp.Format(″〈TD〉%s〈/TD〉/n″,

strVARIANT(rstMyTable.Fields[i].GetValue));

  stPage+=stTemp;}

  (三)重構基類CHttpServer的成員函數(shù)HttpExtensionProc

  1.從EXTENSION_CONTROL_BLOCK*pECB取得查詢字串,再由函數(shù)ParseInput解析此字符串,得出客戶端的各數(shù)據(jù)域的輸入值:數(shù)據(jù)庫名,表名,字段名,字段值;

  2.由函數(shù)cdbSetupPage輸出數(shù)據(jù)庫查詢結果字符串stPage;

  3.用EXTENSION—CONTROL—BLOCK對象的ServerSupportFunction方法向客戶瀏覽器輸出查詢結果字符串stPage。

  后記

  由于用VisualC++(4.2以上)編制程序時,有很多環(huán)境設置,所以筆者把整個項目(包括源程序和面目設置等)和文檔打了個包,需要的讀者可以E-mail聯(lián)系,地址:zhugeming@263.net。->


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 洪泽县| 罗源县| 紫金县| 泗阳县| 沙雅县| 清流县| 临汾市| 罗平县| 平定县| 海晏县| 克山县| 汾阳市| 宣化县| 乳源| 三江| 电白县| 高要市| 岚皋县| 阳新县| 尤溪县| 九龙县| 抚州市| 乌拉特后旗| 新泰市| 西乌| 同江市| 西华县| 攀枝花市| 嘉定区| 寿宁县| 高要市| 永吉县| 和龙市| 周宁县| 门源| 华亭县| 通榆县| 庆元县| 南雄市| 徐汇区| 射阳县|