qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請(qǐng)?jiān)L問 http://qaseven.github.io/

          使用VC連接Access數(shù)據(jù)庫(kù)的兩種方法

           以前的時(shí)候用VC寫了兩種連接Access數(shù)據(jù)庫(kù)的方法,為了方便以后查找把這兩種方法做一下簡(jiǎn)單的介紹。Windows平臺(tái)的數(shù)據(jù)接口標(biāo)準(zhǔn)有ODBC、OLE DB、ADO和Borland的BDE接口,ODBC(Open DataBase Connectivity)只能用于訪問關(guān)系型數(shù)據(jù)庫(kù),為了訪問非關(guān)系型數(shù)據(jù)微軟設(shè)計(jì)了OLE DB接口并在此基礎(chǔ)上推出了ADO(ActiveX Data Objects)。本文介紹的方法是ODBC和ADO。
            一、使用ODBC接口,在這里我們使用MFC的CDatabase類,該類是對(duì)SQLConnect等ODBC的API的封裝。需要包含afxdb.h
          BOOL ODBCConnect(CString strDBFile)
          {
          CString strConnect;
          strConnect.Format(_T("ODBC;DRIVER={MICROSOFT ACCESS DRIVER (*.mdb)};UID=sa;PWD=;DBQ=%s"), strDBFile);
          CDatabase db;
          if(db.Open(NULL, FALSE, FALSE, strConnect))
          {
          //連接數(shù)據(jù)庫(kù)成功
          CRecordset rs(&db);
          CString strSql;
          strSql = _T("select * from info");                                //SQL語(yǔ)句
          rs.Open(AFX_DB_USE_DEFAULT_TYPE, strSql);                        //執(zhí)行Sql語(yǔ)句(可添加 刪除 查詢等)
          if(rs.IsOpen())
          {
          CDBVariant variant;
          rs.MoveFirst();
          while(!rs.IsEOF())
          {
          //讀取記錄
          rs.GetFieldValue(_T("姓名"), variant);
          rs.MoveNext();
          }
          }
          db.Close();
          return TRUE;
          }
          return FALSE;
          }
           二、使用ADO連接數(shù)據(jù)庫(kù),因?yàn)橐褂肅OM,需要初始化(CoInitialize).然后就可以生成接口的對(duì)象操作,代碼如下:
          #import "C:Program Files/Common Files/System/ado/msado15.dll" rename("EOF", "adoEOF")    //生成C++類,改變EOF函數(shù)的名稱
          using namespace ADODB;
          BOOL ADOConnect(CString strDBFile)
          {
          _ConnectionPtr pConnection;
          if(pConnection.CreateInstance(__uuidof(Connection)) != S_OK)
          {
          return FALSE;
          }
          CString strConnect;
          strConnect.Format(_T("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s"), strDBFile);
          if(pConnection->Open(_bstr_t(strConnect), "", "", adModeUnknown) == S_OK)
          {
          //連接數(shù)據(jù)庫(kù)成功
          _RecordsetPtr pRecordset;
          if(pRecordset.CreateInstance(__uuidof(Recordset)) != S_OK)
          {
          pConnection->Close();
          return FALSE;
          }
          CString strSql;
          strSql = _T("select * from info");
          HRESULT hr = pRecordset->Open(_bstr_t(strSql), _variant_t((IDispatch*)pConnection, TRUE), adOpenUnspecified, adLockUnspecified, adCmdUnknown);
          if(hr != S_OK)
          {
          pConnection->Close();
          return FALSE;
          }
          _variant_t vt;
          pRecordset->MoveFirst();
          while(!pRecordset->adoEOF)
          {
          vt = pRecordset->Fields->GetItem("姓名")->Value;
          pRecordset->MoveNext();
          }
          pConnection->Close();
          return TRUE;
          }
          return FALSE;
          }

          posted on 2014-08-27 10:41 順其自然EVO 閱讀(165) 評(píng)論(0)  編輯  收藏 所屬分類: 測(cè)試學(xué)習(xí)專欄

          <2014年8月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          31123456

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 枣阳市| 闽侯县| 宜都市| 舟曲县| 沁源县| 连山| 宜良县| 二连浩特市| 南木林县| 新沂市| 城固县| 屏东市| 克什克腾旗| 洪雅县| 龙陵县| 时尚| 沁源县| 东乌| 丹东市| 涞水县| 宜君县| 孟津县| 涡阳县| 襄汾县| 彰化县| 阳江市| 黄冈市| 塘沽区| 乐安县| 额敏县| 德江县| 耿马| 平南县| 外汇| 汝城县| 新龙县| 彩票| 邢台市| 香河县| 五寨县| 建昌县|