VC6.0数据库编程之ADO

                                                                                         VC6.0数据库编程之ADO
      在谈论了ODBC后,再来看一下使用ADO技术开发数据库管理系统的一些相关问题。
      ADO是Microsoft为OLE DB 而设计的,它为操作OLE DB数据源提供了一套高层次自动化接口。ADO 最主要的优点是易于使用、速度快、内存支出少和磁盘遗迹小。OLE DB是一组”组件对象模型”(COM) 接口,由于本人没有使用过OLE DB,关于OLE DB的问题以后在讨论。
      首先介绍一下ADO包含的7种对象:
 连接对象(Connection):用来连接数据源,以及除了一些命令和事务
 命令对象(Command):用于处理传递给数据源的命令
 记录集对象(Recordset):用于处理数据的表格集,如获取和修改数据
 域对象(Field):用于表示记录集的类信息,包括列值以及其它信息
 参数对象(Parameter):用于对传送给数据源的命令的参数赋值
 属性对象(Property):用于操作在ADO中使用的其它对象的详细信息
 错误对象(Error):获取ADO数据操作时产生的错误的详细信息
      Visual C++6.0为ADO操作提供了库支持,一般情况下,每个Windows操作系统的C:/Program Files/Common Files/System/ado/目录下都有一个msado*.dll文件,根据Windows版本的不同,该文件可以是msado1.dll、msado15.dll和msado2.dll。在利用Visual C++6.0进行ADO编程时,可以借助Visual C++6.0的import宏,将该库文件引用到工程里,从而使msado*.dll库里的数据和函数声明被应用的代码所使用。(关于dll,有时间将在后面讨论) 通过引用,msado*.dll库在工程里产生了所有ADO对象的描述和声明,这些声明同前面介绍的对象名称基本相似,但它提供的时一些指针,如下:
 _ConnectionPtr:指向ADO的Connect对象的指针。
 _RecordsetPtr:指向ADO的Recordset对象的指针。
 _CommandPtr:指向ADO的Command对象的指针。
 _ParameterPtr:指向ADO的Parameter对象的指针。
 FieldPtr:指向ADO的Field对象的指针。
 ErrorPtr:指向ADO的Error对象的指针。
 PropertyPtr:指向ADO的Property对象的指针。
      下面具体讨论下VC6.0中使用ADO开发数据库的过程:
         1、将ADO代码库引入工程
 ADO代码库封装在StdAfx.h中,一般在StdAfx.h中导入msado*.dll:#import "C:/Program Files/CommonFiles/System/ado
/msado15.dll" no_namespace rename("EOF","MY_EOF"),no_namespace指明不适用命名空间,rename重命名,避免冲突,因为EOF在很多地方都使用,如文件结尾。
         2、初始化com库
 ADO库是一组COM动态库,这意味应用程序在调用ADO前,必须初始化OLE/COM库环境。可以调用CoInitialize(NULL),参数保留。
         3、连接数据库
 连接数据库可以定义一Connect对象的指针,即_ConnectionPtr m_pConn;然后调用Open方法,参数1为连接字串,如果是SQL Server 2000,为"DSN=Test;Provider=MSDASQL",如果是Oracle,则为"Provider=MSDAORA.1;DataSource=Test;PersistSecurityInfo
=True",参数2、3为用户名和密码,参数4为打开方式,adAsyncConnect表示同步,adConnectUnspecified表示异步。也可以给Connection对象的ConnectionString赋值,如:
m_pConn->ConnectionString="Provider=MSDAORA.1;DataSource=Test;PersistSecurityInfo=True;UserId=scott;Password=123",这样,
在调用Open时参数1、2、3为空串,SQL Server同样可以。
 打开数据库后,可以调用Execute执行Sql语句,该函数返回值为一记录集指针,见下。
         4、获取记录集
 首先定义一Recordset对象指针,_RecordsetPtr m_pSet,给m_pSet赋值:m_pSet=m_pConn->Execute("Sql语句",NULL,
adCmdText),也可以直接调用其Open:m_pSet->Open("Sql语句",_varint_t((IDispatch*)m_pConn),adOpenStatic,adLockOptimistic,
adCmdText),动态打开用adOpenDynamic。打开记录集后获取字段值:m_pSet->GetCollect("字段名称"),返回值为_varint_t类型,
要先强制转换成_bstr_t,该类型可自动转换成CString。
         5、关闭并释放对象指针
 先关闭记录集,在关闭连接对象,都使用Close方法,然后都用Release释放指针,注意顺序一样且只能关闭一次。
         6、释放Com库
 调用CoUnInitialize( )释放Com库。

编 者 的 话 5 第1篇 基础篇 6 第1章 数据库原理与访问 7 1.1 数据库基本原理 7 1.1.1 概述 7 1.1.2 桌面数据库 7 1.1.3 对象数据库 8 1.1.4 关系数据库服务器 9 1.1.5 选择适用的数据库 9 1.2 数据库访问技术 10 1.2.1 概述 10 1.2.2 ODBC API 10 1.2.3 ODBC的MFC 11 1.2.4 DAO与RDO 11 1.2.5 OLE DB与ADO 12 1.3 数据库操纵语言SQL 13 1.3.1 SQL命令 13 1.3.2 SQL从句 13 1.3.3 SQL运算符 14 1.3.4 SQL合计函数 14 1.4 小 结 14 第2章 COM与数据库访问 15 2.1 COM的基本原理 15 2.1.1 COM历史 16 2.1.2 COM结构 16 2.1.3 COM优势 17 2.1.4 COM接口 18 2.1.5 COM与数据库访问 19 2.1.6 COM与Internet 19 2.2 ACTIVEX的数据库访问 19 2.2.1 ActiveX简介 19 2.2.2 ActiveX对数据库访问的支持 20 2.3 ATL的数据库访问 20 2.3.1 ATL目标 20 2.3.2 ATL内容简介 22 2.3.3 ATL对数据库访问的支持 22 2.4 小 结 23 第3章 数据库开发过程 23 3.1 阶段1:调查与分析 24 3.2 阶段2:数据建模 24 3.3 阶段3:功能设计 24 3.4 阶段4:选择数据库系统 25 3.5 阶段5:选择数据库访问技术 25 3.6 阶段6:代码设计 25 3.7 阶段7:测试与调试 26 3.8 阶段8:发行产品 26 第4章 VC++数据库开发基础 26 4.1 VC++ 6.0工程创建向导 26 4.2 VC++ 6.0数据库新建工具 27 4.3 VC++ 6.0的数据库工程 29 4.4 小 结 31 第2篇 实例篇 32 第5章 ODBC API编程 33 5.1 了解ODBC API 34 5.2 ODBC API编程步骤 34 5.2.1 步骤1:连接数据源 34 5.2.2 步骤2:分配语句句柄 36 5.2.3 步骤3:准备并执行SQL语句 36 5.2.4 步骤4:获取结果集 37 5.2.5 步骤5:提交事务 38 5.2.6 步骤6:断开数据源连接并释放环境句柄 39 5.3 ODBC API编程实例 39 5.3.1 实例概述 39 5.3.2 实例实现过程 40 5.3.3 编译并运行ODBCDemo1工程 97 5.3.4 ODBCDemo1实例小结 98 5.4 本 章 小 结 99 第6章 MFC ODBC编程 100 6.1 了解MFC ODBC 100 6.1.1 CDatabase 100 6.1.2 CRecordSet 100 6.2 MFC ODBC数据库访问技术 101 6.2.1 记录查询 101 6.2.2 记录添加 102 6.2.3 记录删除 102 6.2.4 记录修改 102 6.2.5 撤销数据库更新操作 103 6.2.6 直接执行SQL语句 103 6.2.7 MFC ODBC的数据库操作过程 103 6.3 MFC ODBC编程实例 104 6.3.1 实例概述 104 6.3.2 实例实现过程 105 6.3.3 编译并运行ODBCDemo2工程 132 6.3.4 ODBCDemo2实例小结 137 6.4 本 章 小 结 137 第7章 DAO数据库编程 138 7.1 DAO的数据访问 138 7.1.1 DAO对象 138 7.1.2 MFC对DAO的支持 139 7.1.3 DAO与ODBC的比较 139 7.1.4 MFC的DAO简介 139 7.2 DAO编程实例 142 7.2.1 实例概述 142 7.2.2 实例实现过程 143 7.2.3 运行DAODemo工程 167 7.2.4 DAODemo实例小结 171 7.3 小 结 172 第8章 OLE DB客户数据库编程 172 8.1 OLE DB原理 172 8.1.1 OLE DB与ODBC 172 8.1.2 OLE DB的结构 173 8.1.3 OLE DB的优越性 173 8.1.4 OLE DB对象 174 8.1.5 OLE DB客户模板结构 177 8.1.6 OLE DB客户模
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值