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

 以前的时候用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;
}
  • 1
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值