#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í)例, //也可以把他看成句柄(電影門票)有里他就有資格使用數(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ù)庫連接真正得到實(shí)現(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í)例化數(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; }
|