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

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条)

报告相同问题?

悬赏问题

  • ¥65 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用