y_yy0
2015-07-14 04:14
采纳率: 20%
浏览 1.4k
已采纳

vc++6.0使用的oracle 9i 如何转换成access2007?

vc++6.0使用的oracle 9i 如何转换成access2007?

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • oyljerry 2015-07-14 04:49
    已采纳
    
    使用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;
    }
    
    
    评论
    解决 无用
    打赏 举报
查看更多回答(3条)

相关推荐 更多相似问题