久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

VC怎么用ADO訪問數據庫

154次閱讀
沒有評論

共計 4583 個字符,預計需要花費 12 分鐘才能閱讀完成。

本篇內容介紹了“VC 怎么用 ADO 訪問數據庫”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓丸趣 TV 小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

一、ADO 概述
ADO 是 Microsoft 為最新和最強大的數據訪問范例 OLE DB 而設計的,是一個便于使用的應用程序層接口。ADO 使您能夠編寫應用程序以通過 OLE. DB 提供者訪問和操作數據庫服務器中的數據。ADO 最主要的優點是易于使用、速度快、內存支出少和磁盤遺跡小。ADO 在關鍵的應用方案中使用最少的網絡流量,并且在前端和數據源之間使用最少的層數,所有這些都是為了提供輕量、高性能的接口。之所以稱為 ADO,是用了一個比較熟悉的暗喻,OLE 自動化接口。

OLE DB 是一組”組件對象模型”(COM) 接口,是新的數據庫低層接口,它封裝了 ODBC 的功能,并以統一的方式訪問存儲在不同信息源中的數據。OLE DB 是 Microsoft UDA(Universal Data Access) 策略的技術基礎。OLE DB 為任何數據源提供了高性能的訪問,這些數據源包括關系和非關系數據庫、電子郵件和文件系統、文本和圖形、自定義業務對象等等。也就是說,OLE DB 并不局限于 ISAM、Jet 甚至關系數據源,它能夠處理任何類型的數據,而不考慮它們的格式和存儲方法。在實際應用中,這種多樣性意味著可以訪問駐留在
Excel 電子數據表、文本文件、電子郵件 / 目錄服務甚至郵件服務器,諸如 Microsoft Exchange 中的數據。但是,OLE DB 應用程序編程接口的目的是為各種應用程序提供最佳的功能,它并不符合簡單化的要求。您需要的 API 應該是一座連接應用程序和 OLE DB 的橋梁,這就是 ActiveX Data Objects (ADO)。

二、在 VC 中使用 ADO(開發步驟如下:)

1、引入 ADO 庫文件

使用 ADO 前必須在工程的 stdafx.h 頭文件里用直接引入符號 #import 引入 ADO 庫文件, 以使編譯器能正確編譯。代碼如下所示:

用 #import 引入 ADO 庫文件

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

這行語句聲明在工程中使用 ADO,但不使用 ADO 的名字空間,并且為了避免常數沖突,將常數 EOF 改名為 adoEOF。現在不需添加另外的頭文件,就可以使用 ADO 接口了。

2、初始化 OLE/COM 庫環境
必須注意的是,ADO 庫是一組 COM 動態庫,這意味應用程序在調用 ADO 前,必須初始化 OLE/COM 庫環境。在 MFC 應用程序里,一個比較好的方法是在應用程序主類的 InitInstance 成員函數里初始化 OLE/COM 庫環境。

BOOL CMyAdoTestApp::InitInstance()
{
if(!AfxOleInit())// 這就是初始化 COM 庫
{
AfxMessageBox(“OLE 初始化出錯!”);
return FALSE;
}

……

}

3、ADO 接口簡介

ADO 庫包含三個基本接口:_ConnectionPtr 接口、_CommandPtr 接口和_RecordsetPtr 接口。
_ConnectionPtr 接口返回一個記錄集或一個空指針。通常使用它來創建一個數據連接或執行一條不返回任何結果的 SQL 語句,如一個存儲過程。使用_ConnectionPtr 接口返回一個記錄集不是一個好的使用方法。對于要返回記錄的操作通常用_RecordserPtr 來實現。而用_ConnectionPtr 操作時要想得到記錄條數得遍歷所有記錄,而用_RecordserPtr 時不需要。

_CommandPtr 接口返回一個記錄集。它提供了一種簡單的方法來執行返回記錄集的存儲過程和 SQL 語句。在使用_CommandPtr 接口時,你可以利用全局_ConnectionPtr 接口,也可以在_CommandPtr 接口里直接使用連接串。如果你只執行一次或幾次數據訪問操作,后者是比較好的選擇。但如果你要頻繁訪問數據庫,并要返回很多記錄集,那么,你應該使用全局_ConnectionPtr 接口創建一個數據連接,然后使用_CommandPtr 接口執行存儲過程和 SQL 語句。

_RecordsetPtr 是一個記錄集對象。與以上兩種對象相比,它對記錄集提供了更多的控制功能,如記錄鎖定,游標控制等。同_CommandPtr 接口一樣,它不一定要使用一個已經創建的數據連接,可以用一個連接串代替連接指針賦給_RecordsetPtr 的 connection 成員變量,讓它自己創建數據連接。如果你要使用多個記錄集,最好的方法是同 Command 對象一樣使用已經創建了數據連接的全局_ConnectionPtr 接口
,然后使用_RecordsetPtr 執行存儲過程和 SQL 語句。

4、使用_ConnectionPtr 接口
_ConnectionPtr 主要是一個連接接口,取得與數據庫的連接。它的連接字符串可以是自己直接寫,也可以指向一個 ODBC DSN。

_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();

6、使用_CommandPtr 接口
_CommandPtr 接口返回一個 Recordset 對象,并且提供了更多的記錄集控制功能,以下代碼示例了使用_CommandPtr 接口的方法:

代碼: 使用_CommandPtr 接口獲取數據

_CommandPtr pCommand;
_RecordsetPtr pRs;
pCommand.CreateInstance(__uuidof(Command));
pCommand- ActiveConnection=pConn;
pCommand- CommandText= select * from student
pCommand- CommandType=adCmdText;
pCommand- Parameters- Refresh();
pRs=pCommand- Execute(NULL,NULL,adCmdUnknown);
_variant_t varValue = pRs- GetCollect(name
Cstring strValue=(char*)_bstr_t(varValue);

7、關于數據類型轉換由于 COM 對象是跨平臺的,它使用了一種通用的方法來處理各種類型的數據,因此 Cstring 類和 COM 對象是不兼容的,我們需要一組 API 來轉換 COM 對象和 C ++ 類型的數據。_vatiant_t 和_bstr_t 就是這樣兩種對象。它們提供了通用的方法轉換 COM 對象和 C ++ 類型的數據

“VC 怎么用 ADO 訪問數據庫”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注丸趣 TV 網站,丸趣 TV 小編將為大家輸出更多高質量的實用文章!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-28發表,共計4583字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 凤凰县| 治县。| 黑山县| 浪卡子县| 广德县| 岑巩县| 渝中区| 大悟县| 伊春市| 三都| 合江县| 曲阜市| 永安市| 三门县| 灵武市| 新宁县| 大田县| 鹿泉市| 金华市| 宁强县| 延吉市| 元谋县| 灯塔市| 二连浩特市| 吉木萨尔县| 祥云县| 报价| 冀州市| 安溪县| 华安县| 侯马市| 女性| 丰都县| 旌德县| 陵川县| 榆林市| 阿鲁科尔沁旗| 天气| 阜宁县| 越西县| 浦县|