以前的時(shí)候用VC寫(xiě)了兩種連接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)只能用于訪問(wèn)關(guān)系型數(shù)據(jù)庫(kù),,為了訪問(wèn)非關(guān)系型數(shù)據(jù)微軟設(shè)計(jì)了OLE DB接口并在此基礎(chǔ)上推出了ADO(ActiveX Data Objects),。本文介紹的方法是ODBC和ADO。
一,、使用ODBC接口,,在這里我們使用MFC的CDatabase類(lèi),該類(lèi)是對(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++類(lèi),改變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; } |
|
來(lái)自: viki > 《我的圖書(shū)館》