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

来源:互联网 发布:安卓mac一键修改软件 编辑:程序博客网 时间:2024/05/22 14:51

以前的时候用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;
}



http://blog.csdn.net/wanshi131/article/details/1758790


原创粉丝点击