·幻想~@@~ 發(fā)表于 2007-9-2 22:15:00
數(shù)據(jù)庫
下載第一、配置數(shù)據(jù)源
控制面板 -> 管理工具 ->數(shù)據(jù)源(ODBC)
為什么要設(shè)置數(shù)據(jù)源?
設(shè)置數(shù)據(jù)源的目的是為了我們的程序可以很好的訪問數(shù)據(jù)庫資源。
第二、代碼及解析:(建議運(yùn)行一下,這個代碼)
#i nclude <iostream.h>
#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename ("EOF", "adoEOF")
//ADO連接數(shù)據(jù)庫所需的dll,編譯的時候系統(tǒng)會為我們生成msado15.tlh,ado15.tli兩個C++頭文件來定義ADO庫
//注意這里的import一定要放在一行
int main(){
//該程序使用ADO連接ACCESS(裝office的時候里面有)數(shù)據(jù)庫 后綴為.mdb 運(yùn)行平臺vc6.0
//2003平臺在寫著
//---------------------------------------------------------------------------------
//ADO數(shù)據(jù)庫連接分五步走,
//第一、獲取連接(只到數(shù)據(jù)庫在什么地方)
//第二、打開連接 open(必要的用戶名和密碼)
//第三、獲取字符集 ResultSet(類似數(shù)組的數(shù)據(jù)存儲對象),
//第四、顯示數(shù)據(jù)
//第五、關(guān)閉數(shù)據(jù)集、關(guān)閉連接
//創(chuàng)建個連接對象
_ConnectionPtr m_pConnection;
//對連接進(jìn)行初始化
CoInitialize(NULL);
//---------------------------------------------------------------------------------
//第一步、獲取連接
//---------------------------------------------------------------------------------
//同過連接(Connection)創(chuàng)建并獲取一個數(shù)據(jù)庫連接實例,
//也可以把他看成句柄(電影門票)有里他就有資格使用數(shù)據(jù)庫里的資源了 呵呵
m_pConnection.CreateInstance(__uuidof(Connection));
// 又于在數(shù)據(jù)庫連接的時候有有可能會出現(xiàn)錯誤,比如數(shù)據(jù)源設(shè)置或用戶名 密碼錯誤等
//所以使用try{....}catch(){...}捕獲try{}里的異常(錯誤)
//并把這些異常放到_com_error e 這個變量里,我們可以同過他獲取錯誤的信息
//并且,在出錯的時候程序一定回運(yùn)行catch(){....}里的東西,我們看到如果連接錯誤的時候
//會執(zhí)行cout<<"數(shù)據(jù)庫連接失敗,確認(rèn)數(shù)據(jù)庫mydb.mdb是否在當(dāng)前路徑下!"<<endl;
// return FALSE; 之后推出程序 。如果不加try的話可以在程序出錯的時候造成死機(jī)
//所以,try也可以看成一種出錯的處理(異常處理)
try
{ //---------------------------------------------------------------------------------
//第二步、打開連接 參數(shù)用 ; 分開
//---------------------------------------------------------------------------------
//第一個是Provider=Microsoft.Jet.OLEDB.4.0; access的廠商
//Data Source=mydb.mdb","","",adModeUnknown 數(shù)據(jù)庫名稱 , 用戶名(空) ,密碼(空), 缺省連接模式
//對于該參數(shù):~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ (1)
/*adModeUnknown:缺省。當(dāng)前的許可權(quán)未設(shè)置
adModeRead:只讀
adModeWrite:只寫
adModeReadWrite:可以讀寫
adModeShareDenyRead:阻止其它Connection對象以讀權(quán)限打開連接
adModeShareDenyWrite:阻止其它Connection對象以寫權(quán)限打開連接
adModeShareExclusive:阻止其它Connection對象打開連接
adModeShareDenyNone:允許其它程序或?qū)ο笠匀魏螜?quán)限建立連接
*/
//通過這個語句我們的數(shù)據(jù)庫連接真正得到實現(xiàn)了,m_pConnection有了內(nèi)容了(被附值了)
m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=mydb.mdb","","",adModeUnknown);
}
catch(_com_error e) //捕捉異常
{
cout<<"數(shù)據(jù)庫連接失敗,確認(rèn)數(shù)據(jù)庫mydb.mdb是否在當(dāng)前路徑下!"<<endl;
return FALSE;
}
//數(shù)據(jù)集對象
_RecordsetPtr m_pRecordset;
//實例化數(shù)據(jù)集
m_pRecordset.CreateInstance(__uuidof(Recordset));
//---------------------------------------------------------------------------------
//第三步、獲取數(shù)據(jù)集
//---------------------------------------------------------------------------------
//雖然,前面連接上了,但連接的這個數(shù)據(jù)庫里是不是有數(shù)據(jù)表(test表)還不能確定
//所以,這里同樣要捕獲可能出現(xiàn)的錯誤
try
{
m_pRecordset->Open("SELECT * FROM test", //是數(shù)據(jù)查詢字符串(即所謂的SQL語句)
//通常這些語句分為 數(shù)據(jù)的查詢(select),插入(insert)
//更新(update),刪除(delect)
//是否能執(zhí)行這個命令是由前面(1)確定的
m_pConnection.GetInterfacePtr(), // 獲取庫接庫的IDispatch指針
adOpenDynamic, //動態(tài)光標(biāo)。所有數(shù)據(jù)庫的操作都會立即在各用戶記錄集上反應(yīng)出來
adLockOptimistic, //樂觀鎖定方式。只有在你調(diào)用Update方法時才鎖定記錄。在此之
//前仍然可以做數(shù)據(jù)的更新、插入、刪除等動作
adCmdText); //查詢出來的數(shù)據(jù)是顯示在控制臺里的
}
catch(_com_error *e)
{
cout<<e->ErrorMessage()<<endl;
}
_variant_t var;
char *ID,*name;
try//得到表,但表里不一定有數(shù)據(jù)
{
if(!m_pRecordset->BOF) //數(shù)據(jù)表里是是有數(shù)據(jù)
m_pRecordset->MoveFirst(); //將游標(biāo)(數(shù)據(jù)集在數(shù)據(jù)庫的叫法)移動到一第一條記錄
else {
cout<<"表內(nèi)數(shù)據(jù)為空"<<endl;
return 1;
}
//--------------------------------------------------------------------------------------------------------------------------
// 第四步、顯示數(shù)據(jù)
//---------------------------------------------------------------------------------------------------------------------------
while(!m_pRecordset->adoEOF) //和前面的rename ("EOF", "adoEOF") 想對應(yīng) 這里使用的是
//adoEOF代替EOF (當(dāng)然這里如果前面沒有rename也可以使用EOF)
//判斷游標(biāo)是不是到達(dá)最后一條數(shù)據(jù)
{
var = m_pRecordset->GetCollect("ID"); //這是獲取表中字段的一種方法“ID”為表字段名
if(var.vt != VT_NULL) //判斷記錄在該有沒數(shù)據(jù)
ID= _com_util::ConvertBSTRToString((_bstr_t)var); //由于得到的數(shù)據(jù)可能不是字符傳 這里要轉(zhuǎn)換
//將他們轉(zhuǎn)成字符串,從而可以在屏幕上顯示
var = m_pRecordset->GetCollect("name");
if(var.vt != VT_NULL)
name=_com_util::ConvertBSTRToString((_bstr_t)var);
cout<<ID<<" is "<<name<<endl; //打印該記錄
m_pRecordset->MoveNext(); //游標(biāo)向走向下條記錄
}
}
catch(_com_error *e) //捕獲異常
{
cout<<e->ErrorMessage()<<endl; //如有錯誤 ,將錯誤輸出
}
//--------------------------------------------------------------------------------------
//關(guān)閉數(shù)據(jù)集
//-----------------------------------------------------------------------------------
m_pRecordset->Close();
m_pRecordset = NULL;
//--------------------------------------------------------------------------------------
//關(guān)閉數(shù)據(jù)庫連接
//--------------------------------------------------------------------------------------
if(m_pConnection->State)
m_pConnection->Close();
m_pConnection= NULL;
//這兩步是一定要做的,否則時間長內(nèi)存可能會被用盡
return 0;
}
·
閱讀全文(5837) |
回復(fù)(9) |
引用通告(0) |
編輯標(biāo)簽:
ADO連接ACCESS詳解上一篇:
C++托管設(shè)置 下一篇:
由尚德系列講座之linux內(nèi)核編程入門Re:VC++ ADO連接ACCESS詳解
·訪客w06Evi(游客)發(fā)表評論于2009-8-21 12:12:28
這是ODBC連接吧,ADO是不需要你這樣先配置數(shù)據(jù)源的.
·個人主頁 |
引用 |
返回 |
刪除 |
回復(fù)Re:VC++ ADO連接ACCESS詳解
·訪客0FVh8L(游客)發(fā)表評論于2009-5-9 12:41:00
CoInitialize(NULL);
CString sql=_T("select * from Table");
CString strPath=_T("provider =Microsoft.jet.oledb.4.0;data Source=port.mdb");
_ConnectionPtr pCon;
_RecordsetPtr pRes;
try
{
pCon.CreateInstance("ADODB.Connection");
HRESULT hr= pCon->Open((_bstr_t)strPath,"","",adModeUnknown);//運(yùn)行到這就出錯,為什么呢??希望給講解一下
if (FAILED(hr))
{
MessageBox(_T(" connection error"));
pRes->Close();
pCon->Close();
return;
}
pRes.CreateInstance("ADODB.Recordset");
hr=pRes->Open((_variant_t) sql,pCon.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);
if (FAILED(hr))
{
MessageBox(_T("open recordset error"));
pRes->Close();
pCon->Close();
return;
}
}
catch (_com_error *e)
{
MessageBox(e->ErrorMessage());
pRes->Close();
pCon->Close();
}
pRes->MoveFirst();
while(pRes->adoEOF)
{
_variant_t vDk=pRes->Fields->GetItem("dk")->Value;
vDk.ChangeType(VT_BSTR);
CString strDk=vDk.bstrVal;
int pos=strDk.Find('/');
CString dk=strDk.Left(pos);
CString lx=strDk.Right(pos);
MessageBox(dk);
}
pRes->Close();
pCon->Close();
OnOK();