首    页 界面/窗口 网络/通讯 数据库 组件开发 图像/多媒体 NET/Web 其它技术 源码下载 资料下载 软件共享 软件外包 曲艺杂谈
栏目导航:  首    页  |  数据库  |  Access   


使用VC连接Access数据库的两种方法


原作者:不详    源出处:CSDN    发布者:施昌权    发布类型:转载    发布日期:2008-10-24


以前的时候用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;
}
          
关于我们 版权声明 广告服务 联系我们 友情链接 加入收藏
站长:施昌权    Email:scq2099yt@163.com    MSN:scq2099yt@live.cn    QQ:14046300    本站QQ群:67202409
Copyright © 2008     卓为VC(www.joyvc.cn)    All Rights Reserved    建议分辨率 1024×768
本站由施昌权制作维护
京ICP备09012297号