…………………………………………………………Page 365……………………………………………………………
Visual C++ 6。0 程序设计从入门到精通
//根据连接字符串开启数据连接,得到结果集
m_recordSet…》Open(〃select * from Contact〃; m_connection。GetInterfacePtr(); adOpenDynamic;
adLockOptimistic; adCmdText);
注意:当比较频繁的访问数据库的时候,最好先用全局_ConnectionPtr 接口创建一个数据连接,
然后用_ResultsetPtr 接口来处理数据。本章第 6 节的例子便是采用的这种方法。
获得记录集后,可以利用 MoveNext() 函数方便的实现记录集的遍历,代码如下:
while(!m_Recordset…》adoEOF)
{
…
//获得下一条记录
m_Recordset…》MoveNext();
}
当然,利用 12。5 节介绍的其他方法也可以较为方便地实现记录集的遍历,读者可以自己
编码实验。
12。6。4 对记录的操作
对记录的操作主要有添加、修改和删除 3 种。
1.添加记录
打开记录集后,就可以往里面添加记录了,添加一条记录一般按如下步骤进行。
o 调用 Recordset 对象的 AddNew()方法新增一个空记录。
o 调用 Recordset 对象的 PutCollect()方法输入每个字段的值。
o 调用 Recordset 对象的 Update()方法更新数据库中的数据。
下面是添加记录的一段代码:(假设 m_ID 、m_Name 、m_Telephone 和 m_Address 均为
已经赋值的变量)
m_Recordset…》AddNew();
m_Recordset…》PutCollect(〃ID〃; m_ID);
m_Recordset…》PutCollect(〃Name〃; _variant_t(m_Name));
m_Recordset…》PutCollect(〃Telephone〃; m_Telephone);
m_Recordset…》PutCollect(〃Address〃; _variant_t(m_Address));
m_Recordset…》Update();
2 .修改记录
修改一条记录通常按如下步骤进行。
o 调用 Recordset 对象的 PutCollect()方法给当前记录的每个字段赋值。
o 调用 Recordset 对象的 Update()方法更新数据库中的数据。
以下是修改当前记录的代码:
m_Recordset…》PutCollect(〃ID〃; m_NewID);
·354 ·
…………………………………………………………Page 366……………………………………………………………
第 12 章 数据库开发
m_Recordset…》PutCollect(〃Name〃; _variant_t(m_NewName));
m_Recordset…》PutCollect(〃Telephone〃; m_NewTelephone);
m_Recordset…》PutCollect(〃Address〃; _variant_t(m_NewAddress));
m_Recordset…》Update();
3 .删除记录
利用 Recordset 对象的 Delete()方法很容易删除记录。Delete()方法的原型如下:
Delete(enum AffectedEnum AffectRecords);
参数 AffectRecords 是一个枚举型变量,用于指定删除方式。如果为此变量赋值
adAffectCurrent,则只有当前记录被删除;如果赋值为 adAffectedGroup,则符合过滤器的所
有行都被删除。下面一段代码将当前记录删除:
m_Recordset…》Delete(asAffectCurrent);
m_Recordset…》Update();
12。6。5 关闭记录集
当所有操作结束后,应当关闭记录集及当前连接,分别调用 Recordset 对象和 Connection
对象的 Close()方法即可,代码如下:
//关闭记录集
if (m_recordSet != NULL)
m_recordSet…》Close();
//关闭连接
if (m_connection !=NULL)
m_connection…》Close();
12。7 利用 ADO 查询并操作数据库实例
实例 12…2:ADO 使用实例。源代码在光盘中“12实例 12…2AdoTest”目录下。
前面讲了很多 ADO 的基础知识,读者也应该对 ADO 有了一个基本的了解,并且知道了
ADO 的常用函数和操作数据库的步骤。下面即将进行实际操作,这里将利用上面所讲的知识
编写一个程序,达到查询和操作数据库的目的。
在具体编写程序前,还要了解一下经常用到的两种类型,即_variant_t 和_bstr_t 。它们是
两个类,分别继承了 VARIANT 和 BSTR ,并增加了一些方法。之所以引入这两种数据类型,
是因为 必须设计成跨平台,在 里用不了 CString 类,这时需要有一种更普遍的方
式来处理字符串以及其他数据。VARIANT 就是一个巨大的 union ,包含了除 char * 以外的所
有的数据类型,BSTR 取代了 char* 。利用新引入的这两种类型,会使编程更加方便。比如从
结果集 rs 中读取数据,然后放到 List Box 控件 m_List 中。如果采用新的类型,具体代码如
下:
·355 ·
…………………………………………………………Page 367……………………………………………………………
Visual C++ 6。0 程序设计从入门到精通
_variant_t Holder;
Holder = rs…》GetCollect(〃FIELD_1〃);
m_List。AddString((char*)_bstr_t(Holder));
对比一下没有采用_variant_t 和 _bstr_t 的代码:
COleVariant covFieldValuel;
VARIANT vFieldValue;
CString Holder;
Rs…》GetFieldValue(〃FIELD_1〃; covFieldValue);
vFieldValue = (LPVARIANT)covFieldValue;
Holder。Format(〃%s〃;vFieldValue…》pbVal);
m_List。AddString(Holder);
另外在编写程序时要用 try 和 catch,否则 ADO 调用错误有可能使程序崩溃,一定要随
时记得捕捉__error 例外以及其他错误。
此外,在第 2 节介绍如何设置 ODBC 数据源时提到了利用 组件 DataSourceLocator ,
用户可以在程序运行的过程中动态设置数据源 。至于如何利用此组件,将在程序中详细说明。
下面具体介绍该程序的编写过程。
1.创建工程
新建一个 MFC 工程,取名为 AdoTest ,在第一步中选择单文档,在最后一步的基类选择
CFormView,分别如图 12…20 和图 12…21 所示。
图 12…20 单文档工程 图 12…21 基类选择 CFormView 类
2 .链入 ADO 库文件
在文件“stdafx。h ”中加入如下语句:
#import 〃C:Program Filesmon Filessystemole dboledb32。dll〃 no_namespace
#import 〃c:program filesmon filessystemadomsado15。dll〃 no_namespace rename(〃EOF〃; 〃adoEOF〃)
加入第二个语句前面已经讲过原因,加入第一个语句是由于在程序中将要采用 组
件 DataSourceLocator 。这里需要注意一点,两个 import 语句中都用了 no_namespace ,当引入
·356 ·
…………………………………………………………Page 368……………………………………………………………
小说推荐
- C语言游戏编程从入门到精通(PDF格式)
- -Page 1-Page 2-Page 3-Page 4-Page 5-Page 6-Page 7-Page 8-Page 9-Page 10-Page 11-Page 12-Page 13-Page 14
- 其他
- 最新章:第4章
- oracle从入门到精通(PDF格式)
- -Page 1-Oracle 从入门到精通-Page 2-资源来自网络,仅供学习 Oracle 从入门到精通一、SQL 8
- 其他
- 最新章:第37章
- php程序设计简明教程(DOC格式)
- -Page 1-PHP 程序设计简明教程PHP 讲义 第 1 页 共 90 页-Page 2-目录序 4第一章 PHP 简介 6
- 其他
- 最新章:第31章
- VB2008从入门到精通(PDF格式英文版)
- -Page 1(R)The eXperT’s Voice inBeginningVB 2008From Novice to ProfessionalChristian Gross-Page 2-Page 3-Beginning VB 2008From Novice to Professional■C
- 其他
- 最新章:第214章
- C语言设计
- 作者:谭浩强1 C 语言概述1.1 C语言的发展过程1.2 当代最优秀的程序设计语言1.3 C语言版本1.4 C语言的特点1.5 面向对象的程序设计语言1.6 C和C+1.7 简单的C程序介绍1.8 输入和输出函数1.9 C源程序的结构特点1.10书写程序时应遵循的规则1.11C语言的字符集1.12
- 文学名著
- 最新章:第45章
- 设计成婚:不入豪门
- 作者:海未央《设计成婚2:名门新娘》作品介绍《名门新娘》介绍:她是骆家收养的孤女,性格因为受他的影响,变得有些古灵精怪,也懂得是非之分!他说他的一切只为他而努力,可是为什么要拒绝自己呢?什么?没有满十八岁?那今天生日,够十八岁了吧?什么,还太小?太过分了,这不是耍着自己玩吗?嘿嘿,有个邪恶的老师,那
- 魔法玄幻
- 最新章:第196章
- 玄学,从入门到放弃
- 《玄学,从入门到放弃》作者:李传言文案:周诣一手拿着卜卦,一手拿着《演员的自我修养,叹息良久。他本是百年前观天占星的玄术师,谁知却一朝重生现代。他只想平淡地生活下去,可天不遂人愿,他注定将在这末法时代掀起波澜!成就一代影帝!谢千仇沉默地看着他…大师,你卦和书都拿倒了#玄学,从入门到放弃,入土,删库跑
- 魔法玄幻
- 最新章:第86章
- C语言实例教程(PDF格式)
- -Page 1-前 言Visual C+是开发运行于Windows 95和Windows NT环境下的Win32应用程序的可视化编程工具中最重要的成员之一,它为软件开发人员提供了完整的编辑、编译和调试工具和建立于Win32 API(ApplicationProgramming Interface)基
- 其他
- 最新章:第143章
- 要你言听计从
- 作者:决明第一章哈士奇,没有护卫看家的本领,对主人、客人甚至是闯空门的恶人都一样友善,咬着皮球跟小偷一块玩你丢我捡也不用太惊讶,时常被人认为忠诚度不足。贺世祺背靠在冰冷玻璃落地窗前,一整间屋子都是伸手不见五指的黑暗,也好,反正他现在什么也不需要看到,只要耳朵还有听觉就好,顺便听听贴在耳边的手机里还要
- 都市言情
- 最新章:第28章