二、使用#import方法的编程步骤
这里建议您使用#import的方法,因为它易学、易用,代码也比较简洁。
1、 添加#import指令
打开stdafx.h文件,将下列内容添加到所有的include指令之后:
#include <icrsint.h> //Include support for VC++ Extensions #import "C:\Program Files\Common Files\System\ADO\msado15.dll" \ no_namespace rename("EOF", "adoEOF") |
其中icrsint.h文件包含了VC++扩展的一些预处理指令、宏等的定义,用于COM编程时使用。
2、定义_ConnectionPtr型变量,并建立数据库连接
建立了与数据库服务器的连接后,才能进行其他有关数据库的访问和操作。ADO使用Connection对象来建立与数据库服务器的连接,所以它相当于MFC中的CDatabase类。和CDatabase类一样,调用Connection对象的Open方法即可建立与服务器的连接。
数据类型 _ConnectionPtr实际上就是由类模板_com_ptr_t而得到的一个具体的实例类,其定义可以到msado15.tlh、comdef.h 和comip.h这三个文件中找到。在msado15.tlh中有:
_COM_SMARTPTR_TYPEDEF(_Collection, __uuidof(_Collection)); |
经宏扩展后就得到了_ConnectionPtr类。_ConnectionPtr类封装了Connection对象的Idispatch接口指针,及一些必要的操作。我们就是通过这个指针来操纵Connection对象。类似地,后面用到的_CommandPtr和_RecordsetPtr类型也是这样得到的,它们分别表示命令对象指针和记录集对象的指针。
(1)、连接到MS SQL Server
注意连接字符串的格式,提供正确的连接字符串是成功连接到数据库服务器的第一步,有关连接字符串的详细信息参见微软MSDN Library光盘。
本例连接字符串中的server_name,database_name,user_name和password在编程时都应该替换成实际的内容。
_ConnectionPtr pMyConnect=NULL; HRESULT hr=pMyConnect.CreateInstance(__uuidof(Connection))); if(FAILED(hr))return;
_bstr_t strConnect="Provider=SQLOLEDB; Server=server_name;" "Database=database_name; uid=user_name; pwd=password;"; //connecting to the database server now: try{pMyConnect->Open(strConnect,"","",NULL);} catch (_com_error &e) { ::MessageBox(NULL,e.Description(),"警告",MB_OK │ MB_ICONWARNING); } |
注意Connection对象的Open方法中的连接字符串参数必须是BSTR或_bstr_t类型。另外,本例是直接通过OLE DB Provider建立连接,所以无需建立数据源。
(2)、通过ODBC Driver连接到Database Server连接字符串格式与直接用ODBC编程时的差不多:
_bstr_t strConnect="DSN=datasource_name; Database=database_name; uid=user_name; pwd=password;"; |
此时与ODBC编程一样,必须先建立数据源。
3、定义_RecordsetPtr型变量,并打开数据集
定义_RecordsetPtr型变量,然后通过它调用Recordset对象的Open方法,即可打开一个数据集。所以Recordset对象与MFC中的CRecordset类类似,它也有当前记录、当前记录指针的概念。如:
_RecordsetPtr m_pRecordset; if(!FAILED(m_pRecordset.CreateInstance( __uuidof( Recordset ))) { m_pDoc->m_initialized=FALSE; return; }
try{ m_pRecordset->Open(_variant_t("mytable"), _variant_t((IDispatch *)pMyConnect,true), adOpenKeyset, adLockOptimistic, adCmdTable); } catch (_com_error &e) { ::MessageBox(NULL,"无法打开mytable表。","提示", MB_OK │ MB_ICONWARNING); } |
Recordset对象的Open方法非常重要,它的第一个参数可以是一个SQL语句、一个表的名字或一个命令对象等等;第二个参数就是前面建立的连接对象的指针。此外,用Connection和Command对象的Execute方法也能得到记录集,但是只读的。
分享到:
相关推荐
### Visual C++ ADO 数据库编程入门 #### 一、ADO技术概述 ##### 1.1 ADO技术简介 ADO (ActiveX Data Objects) 是一种高级数据库编程接口,它基于OLE DB技术之上,专为Windows环境设计。ADO以其强大的数据处理能力...
一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS,不直接与DBMS打交道,所有的数据库操作由对应的DBMS的ODBC驱动程序完成。也就是说,不论是FoxPro、Access还是Oracle数据库,均可用ODBC API进行访问。由此可见...
在数据库编程方面,Visual C++ 6.0通过ODBC(Open Database Connectivity)和ADO(ActiveX Data Objects)等接口,为开发者提供了访问各种类型数据库的能力。 1. ODBC:这是一个标准的数据库接口,允许应用程序通过...
综上所述,Visual C++结合ODBC或ADO可以高效地进行数据库编程,提供了灵活且强大的数据访问能力。无论选择ODBC还是ADO,都能帮助开发者构建跨平台、跨数据库的解决方案,简化了数据库应用程序的开发过程。在选择...
本书由浅入深介绍了强大的开发工具Visual C++6.0与数据库技术。编者精选、设计了100个实用经典的实例,以实例带动知识点,使读者可以快速入门并逐步提高。本书实例操作步骤详细,并配以执行结果,直观明了易于理解。...
通过这十个实例的学习,开发者将能够熟练地运用Visual C++进行数据库编程,掌握从基础的数据库连接到高级的事务处理和数据可视化的各项技能。这些实例不仅有助于理论理解,还提供了可直接应用于实际项目的代码示例。
《Visual C++6.0从入门到精通》是一套针对初学者和中级程序员设计的教程,旨在帮助读者全面掌握Visual C++6.0这一经典编程工具。本教程深入浅出地介绍了C++语言基础、MFC(Microsoft Foundation Classes)框架、...
8. **数据库编程**:通过ODBC(Open Database Connectivity)和ADO(ActiveX Data Objects),Visual C++ 6可以方便地连接和操作各种数据库。书籍会讲解如何进行数据库操作,创建数据库连接,执行SQL语句等。 9. **...
《Visual C++.NET深入编程电子版》是一本专注于C++编程技术在.NET框架下的应用的专业书籍,主要针对的是Microsoft的Visual C++.NET开发环境。这本书的目的是帮助开发者深入理解C++与.NET平台的结合,以及如何利用这...
综上所述,“Visual C++编程宝典.pdf”这一资料包含了从C++基础知识到高级特性的全面覆盖,适合初学者入门学习,同时也为有经验的开发者提供了深入研究的平台。无论是想要快速掌握C++语言还是深入探索其复杂特性,该...