ADO数据库的操作

导入动态链接库

在使用ADO技术时,需要导入一个ADO动态链接库msado15.dll,该动态链接库位于系统盘的
“Program Files\Common Files\System\ado\”目录下。例如,系统盘是c盘,该文件位于
“C:\Program Files\Common Files\System\ado\”目录。在Visual c++中,需要使用预处理
命令“#import”将动态链接库导入到系统中,通常情况下,在“StdAfx.h”头文件中导入文件。

在工作区窗口选择File View视图,打开StdAfx.h头文件,加入以下代码

#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace \
	rename("EOF","adoEOF") rename("BOF","adoBOF")

在上边代码中通过预编译指令#import来告诉编译器将动态链接库导入到程序中,no_namespace
则指示ADO对象不使用命名空间,第二行代码表示将ADO中的EOF改为adoEOF,将BOF改为
adoBOF,以避免与其他库中的EOF和BOF相冲突

使用ADO智能指针
在适用ADO对象开发应用程序时,有些ADO的支持类可以使ADO对象在使用起来变得更加方便。
_com_ptr_t类就是其中一个,在msado15.dll中基于_com_ptr_t类定义了几种智能指针,包括连接
对象指针(_ConnectionPtr),命令对象指针(_RecordsetPtr),记录集对象指针(_CommandPtr)。

//首先声明一个智能指针
_ConnectionPtr m_pConnection

//通过CreateInstance函数创建对象实例
m_pConnection.CreateInstance("ADODB.Connection");  //第一种方法
m_pConnection.CreateInstance(_uuidof(Connection)); //第二种方法

初始化COM环境

由于ADO库是一个com动态库,因此在应用程序调用ADO之前,必须初始化com环境。在MFC的应用
程序里,通常使用CoInitialize函数初始化com环境。
HRESULT CoInitialize(LPVOID pvReserved);
pvReserved:保留变量,必须是NULL
在程序的InitInstance函数中初始化com环境,代码如下:
::CoInitialize(NULL);
在程序最后还要释放com环境:
::CoUninitialize();
连接数据库
使用ADO连接数据库是通过Connection对象的Open方法实现的
Connection.open(ConnectionString,userID,password,openoptions)
ConnectionString: (可选) 字符串,包含连接信息。参照ConnectionString属性可获得有效设置的详细信息
userID: (可选)字符串,包含建立连接时所使用的用户名
password:(可选)字符串,包含建立连接时所使用的密码
openoptions:(可选)ConnectoptionEnum值。如果设置为adConnectoAsync,则异步打开连接。当连接可用时将产生ConnectComplete事件

ConnectionString属性:

Provier=:指定用来连接的提供者名称。
File Name=:指定包含预先设置连接信息的特定提供者的文件名称(例如持久数据源对象)。
Remote Provider=:指定打开客户端连接时使用的提供者名称(仅限于Remote Data Service)
Remote Server=:指定打开客户端连接时使用的服务器的路径名称(仅限于Remote Data Service)










你可能感兴趣的:(数据库,service,null,System,mfc,编译器)