vc链接mysql数据库的方法

    前段时间项目中用的是mysql数据库,它的链接方法有二种,一种是数据库自带的API,还有一种就用ADO链接了。mysql

    因为本次项目用的mysql数据库只是暂时的,后期可能会更改成MSSQL,因此若是用mysql自带的API链接移植性很差,因此改成ADO的,到时只要修改下字符串链接值就好了。sql

    其实ADO链接的底层也是调用的ODBC驱动去链接,因此须要去下载个数据库对应的ODBC驱动,别人说秘本须要对应,要否则链接不上,我没有作太多测试,本身用的6.0版本,因此去官网下载了个mysql-connector-odbc-5.3.4-winx64版本的,而后对应的字符串为:数据库

driver={MySQL ODBC 5.3 ANSI Driver};Server=localhost;DATABASE=*;USER=*;PASSWORD=*;OPTION=3;

实测是能够链接成功的。ide

下面放出本身写的一个超级简单的类:测试

#pragma once

#import <C:\Program Files\Common Files\System\ADO\msado15.dll> no_namespace rename("EOF", "adoEOF")
// #import "msado15.DLL"   rename_namespace("ADOWE") rename("EOF","adoEOF")  
// using namespace ADOWE;


class CAdoDatabase
{
public:
    CAdoDatabase(void);
public:
    ~CAdoDatabase(void);
public:
    //BOOL Connect(CString csConnectStr,CString csUser,CString csPasswd);
    //链接
    BOOL Connect(CString csConnectStr);
    //断开链接
    BOOL DisConn();
    //执行语句
    BOOL Execute(CString csSQL);
    //是否链接
    BOOL IsConn();
    //返回结果的行数
    int  QueryDataForRecord(CString csSql,CStringArray& csa);
private:
    _ConnectionPtr m_pConn;
    _RecordsetPtr  m_pRecord;
};

实现:ui

BOOL CAdoDatabase::Connect(CString csConnectStr)
{
    HRESULT hr;
    try
    {
        hr = m_pConn.CreateInstance(__uuidof(Connection));
        //hr = m_pConn.CreateInstance("ADODB.Connection");
        //m_pConn->Open(_bstr_t(csConnectStr),"","",ADODB::adConnectUnspecified);
        m_pConn->Open(_bstr_t(csConnectStr),"","",adModeUnknown);
        return TRUE;
    }
    catch (_com_error e)
    {
        CString csErrorMsg;
        csErrorMsg.Format(_T("链接数据库出错:%s"),e.ErrorMessage());
        AfxMessageBox(csErrorMsg,MB_OK+MB_ICONERROR);
        return FALSE;
    }
}

BOOL CAdoDatabase::DisConn()
{
    if (m_pConn->State)
    {
        m_pConn->Close();
        m_pConn = NULL;
        return TRUE;
    }
    return FALSE;
}

BOOL CAdoDatabase::Execute(CString csSQL)
{
    try
    {
        _variant_t RecordsAffected;
        m_pConn->Execute((_bstr_t)csSQL,&RecordsAffected,adCmdText);
        return TRUE;
    }catch(_com_error e)
    {
        CString csMsg;
        csMsg.Format(_T("执行SQL语句出错:%s"),e.ErrorMessage());
        AfxMessageBox(csMsg,MB_OK+MB_ICONERROR);
        return FALSE;
    }
}


int CAdoDatabase::QueryDataForRecord(CString csSql, CStringArray &csa)
{
    try
    {
        m_pRecord.CreateInstance(__uuidof(Recordset));
        //m_pRecord->Open((_bstr_t)csSql,m_pConn.GetInterfacePtr(),adOpenStatic,adLockOptimistic,adCmdText);
        m_pRecord->Open((_bstr_t)csSql,_variant_t((IDispatch *)m_pConn, true),adOpenKeyset,adLockReadOnly,adCmdText);
        int nCount;
        int nRowCount = 0;
        nCount = m_pRecord->Fields->GetCount();
        _variant_t vt;
        while (!m_pRecord->adoEOF)
        {
            for (int i=0; i<nCount; i++)
            {
                vt =m_pRecord->Fields->GetItem(long(i))->GetValue();
                if (vt.vt == VT_NULL)
                {
                    vt = _T("");
                }
                csa.Add(vt);
            }
            nRowCount++;
            m_pRecord->MoveNext();
        }
        m_pRecord->Close();
        return nRowCount;
    }catch(_com_error e)
    {
        CString csMsg;
        csMsg.Format(_T("查询语句出错:%s"),e.ErrorMessage());
        AfxMessageBox(csMsg,MB_OK+MB_ICONERROR);
        return -1;
    }
}


此代码运行平台为WIN7,我把它放到XP上运行时,提示无效指针,网上查了下是平台兼容性的问题,换到其它WIN7电脑上可成功运行。因此也没管它了,有解决的小伙伴,能够提供下方法,谢谢!
spa

相关文章
相关标签/搜索