目前位置: VCer资源中心 >>> VCer论坛 >>> 技术问答

[本帖已阅读533次 分值2 回复0次] 张贴资源 发回信箱 控制面板

请教大哥们一个关于vc中利用ado操作Access2003数据库的问题,急急!!!!!

提供者:baobeizouyi 张贴时间:2007-10-22 14:59:00.0 出处:vcer.net 作者:baobei

请教大哥们一个关于vc中利用ado操作Access2003数据库的问题,急急!!!!!(2007-10-22 14:59:00.0)


baobei


 
级别: VCer小兵
头衔: VCer会员

经验: 84
作品: 8
分会: 华北分会
注册: 2007-10-15 18:37:38.0
登录: 2007-11-26 18:45:42.0

...我在用ado 操作Acess2003的时候,总是出现"数据库连接失败"以下是代码:

#import "c:\program files\common files\system\ado\msado15.dll"no_namespaces rename("EOF" adoEOF")

 

 

BOOL CMyAdoTestApp::InitInstance()

{

if(!AfxOleInit())//这就是初始化COM库

{

AfxMessageBox(“OLE初始化出错!”);

return FALSE;

}

……

}

 

ConnectionPtr pConn;

if (FAILED(pConn.CreateInstance("ADODB.Connection")))

{

AfxMessageBox("Create Instance failed!");

return;

}

CString strSRC;

strSRC="Driver=SQL Server;Server=";

strSRC+="suppersoft";

strSRC+=";Database=";

strSRC+="mydb";

strSRC+=";UID=SA;PWD=";

CString strSQL = "Insert into student(no,name,sex,address) values(3,’aaa’,’male’,’beijing’)";

_variant_t varSRC(strSRC);

_variant_t varSQL(strSQL);

_bstr_t bstrSRC(strSRC);

if (FAILED(pConn->Open(bstrSRC,"","",-1)))

{

AfxMessageBox("Can not open Database!");

pConn.Release();

return;

}

COleVariant vtOptional((long)DISP_E_PARAMNOTFOUND,VT_ERROR);

pConn->Execute(_bstr_t(strSQL),&vtOptional,-1);

pConn.Release();

AfxMessageBox("ok!");

5、使用_RecordsetPtr接口(以连接SQL Server为例)

_RecordsetPtr pPtr;

if (FAILED(pPtr.CreateInstance("ADODB.Recordset")))

{

AfxMessageBox("Create Instance failed!");

return FALSE;

}

CString strSRC;

strSRC="Driver=SQL Server;Server=";

strSRC+="210.46.141.145";

strSRC+=";Database=";

strSRC+="mydb";

strSRC+=";UID=sa;PWD=";

strSRC+="sa";

CString strSQL = "select id,name,gender,address from personal";

_variant_t varSRC(strSRC);

_variant_t varSQL(strSQL);

if(FAILED(pPtr->Open(varSQL,varSRC,adOpenStatic,adLockOptimistic,adCmdText)))

{

AfxMessageBox("Open table failed!");

pPtr.Release();

return FALSE;

}

while(!pPtr->GetadoEOF())

{

_variant_t varNo;

_variant_t varName;

_variant_t varSex;

_variant_t varAddress;

varNo = pPtr->GetCollect ("id");

varName = pPtr->GetCollect ("name");

varSex = pPtr->GetCollect ("gender");

varAddress = pPtr->GetCollect ("address");

CString strNo =(char *)_bstr_t(varNo);

CString strName =(char *)_bstr_t(varName);

CString strSex =(char *)_bstr_t(varSex);

CString strAddress =(char *)_bstr_t(varAddress);

strNo.TrimRight();

strName.TrimRight();

strSex.TrimRight();

strAddress.TrimRight();

int nCount = m_list.GetItemCount();

int nItem = m_list.InsertItem (nCount,_T(""));

m_list.SetItemText (nItem,0,strNo);

m_list.SetItemText (nItem,1,strName);

m_list.SetItemText (nItem,2,strSex);

m_list.SetItemText (nItem,3,strAddress);

pPtr->MoveNext();

}

pPtr->Close();

pPtr.Release();

注:转载文章需注明来源:VCer.net 文章地址:http://vcer.net/1193036340468.html

  如果你觉得VCer.net不错,而且你愿意为VCer.net捐赠一元钱,那么点击后面的捐赠按钮吧:) vcer.net捐赠

[回复该贴] [加入个人书签]