以前的时候用VC写了两种连接Access数据库的方法,为了方便以后查找把这两种方法做一下简单的介绍。Windows平台的数据接口标准有ODBC、OLE DB、ADO和Borland的BDE接口,ODBC(Open DataBase Connectivity)只能用于访问关系型数据库,为了访问非关系型数据微软设计了OLE DB接口并在此基础上推出了ADO(ActiveX Data Objects)。本文介绍的方法是ODBC和ADO。
一、使用ODBC接口,在这里我们使用MFC的CDatabase类,该类是对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)) { //连接数据库成功 CRecordset rs(&db); CString strSql; strSql = _T("select * from info"); //SQL语句 rs.Open(AFX_DB_USE_DEFAULT_TYPE, strSql); //执行Sql语句(可添加 删除 查询等) if(rs.IsOpen()) { CDBVariant variant; rs.MoveFirst(); while(!rs.IsEOF()) { //读取记录 rs.GetFieldValue(_T("姓名"), variant); rs.MoveNext(); } } db.Close(); return TRUE; } return FALSE; } |
二、使用ADO连接数据库,因为要使用COM,需要初始化(CoInitialize).然后就可以生成接口的对象操作,代码如下:
#import "C:Program Files/Common Files/System/ado/msado15.dll" rename("EOF", "adoEOF") //生成C++类,改变EOF函数的名称 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) { //连接数据库成功 _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; } |
最新内容请见作者的GitHub页:http://qaseven.github.io/