友情提示:如果本网页打开太慢或显示不完整,请尝试鼠标右键“刷新”本网页!阅读过程发现任何错误请告诉我们,谢谢!! 报告错误
狗狗书籍 返回本书目录 我的书架 我的书签 TXT全本下载 进入书吧 加入书签

VC语言6.0程序设计从入门到精通-第131章

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!





…………………………………………………………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……………………………………………………………

          
返回目录 上一页 下一页 回到顶部 0 0
未阅读完?加入书签已便下次继续阅读!
温馨提示: 温看小说的同时发表评论,说出自己的看法和其它小伙伴们分享也不错哦!发表书评还可以获得积分和经验奖励,认真写原创书评 被采纳为精评可以获得大量金币、积分和经验奖励哦!