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

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

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






                   //根据连接字符串开启数据连接  



                   m_Connection…》Open( _bstr_t( m_strConnection。GetBuffer(0) ); 〃〃; 〃〃; …1);  



             }  



             //捕获例外__error  



             catch (__error &e)  



             {  



                   GenerateError(e。Error(); e。Description());  



             }  



             //捕捉其他例外  



             catch(。。。) {}  



             //将变量中的值保存到控件中  



             UpdateData( FALSE );  



             //显示表项名  



             getTables();  



 ·362 ·  


…………………………………………………………Page 374……………………………………………………………

                                                                                           第 12 章    数据库开发  



      }  



      按照顺序,为“操作”按钮编写响应函数。代码如下:  



      void CAdoTestView::OnExecute()    



      {  



           // TODO: Add your control notification handler code here  



           try  



           {  



                 //创建实例  



                 m_Recordset。CreateInstance(__uuidof(Recordset));  



                 //将控件中的值保存到变量中,主要是保存 SQL 语句  



                 UpdateData(TRUE);  



                 //设定光标服务  



                 m_Connection…》CursorLocation = adUseClient;  



                 //根据连接字符串开启数据连接,得到结果集  



                 m_Recordset…》Open(m_strSQL。GetBuffer(0);  m_Connection。GetInterfacePtr();  adOpenDynamic;  



adLockOptimistic; adCmdText);  



           }       



           //捕获例外__error  



           catch (__error &e)  



           {  



                 GenerateError(e。Error(); e。Description());  



           }  



           //捕获其他例外  



           catch (。。。) {}  



           //将结果集中的内容在 datagrid 中显示出来  



           m_DataGrid。SetRefDataSource((LPUNKNOWN)m_Recordset);  



           //刷新 DataGrid  



           m_DataGrid。Refresh();  



           //将变量中的值保存到控件中  



           UpdateData(FALSE);  



           //将结果集置空  



           m_Recordset = NULL;  



      }  



      在这段代码中,完成了执行 SQL 语句。这是因为记录集转化成 LPUNKNOWN 类型,然 

后当做参数传给 DataGrid 控件的方法 SetRefDataSource 即可。  

      至此,程序已经可以完成对数据库的操作了,但是为了让程序更加完善,当操作结束时, 

应该关闭记录集和连接,然后退出。最后还需要为“断开”和“退出”按钮编写响应函数。  

      “断开”按钮的响应函数如下:  



      void CAdoTestView::OnDisconnect()    



      {  



                                                                                                           ·363 ·  


…………………………………………………………Page 375……………………………………………………………

Visual C++ 6。0 程序设计从入门到精通  



             // TODO: Add your control notification handler code here  



             try  



             {  



                   //关闭连接  



                   m_Connection…》Close();  



             }  



             //捕获__error 例外  



             catch (__error &e)  



             {  



                   GenerateError(e。Error(); e。Description());  



             }  



             //捕获其他例外  



             catch(。。。) {}  



             //清空 List Box 控件  



             m_ListBox。ResetContent();  



             //将 DataGrid 控件置空  



             m_DataGrid。SetRefDataSource(NULL);  



             //将 DataGrid 控件设置成默认状态  



             m_DataGrid。ClearFields();  



             //刷新 DataGrid  



             m_DataGrid。Refresh();  



             //将 SQL 语句清空  



             //这里不清空连接语句,是为了断开连接以后如果重新连接不需要重新设定数据源  



             m_strSQL = 〃〃;  



             //将变量值保存到控件中  



             UpdateData(FALSE);  



       }  



       为“退出”按钮编写如下响应函数:  



      void CAdoTestView::OnQuit()    



       {  



             // TODO: Add your control notification handler code here  



             try    



             {  



                   //关闭记录集  



                   if (m_Recordset != NULL)  



                          m_Recordset…》Close();  



                   //关闭连接  



                   if (m_Connection !=NULL)  



                          m_Connection…》Close();  



             }  



 ·364 ·  


…………………………………………………………Page 376……………………………………………………………

                                                                              第 12 章    数据库开发  



          //捕获例外  



          catch(。。。){}  



          //退出    



          PostMessage(WM_QUIT);  



     }  



     至此,基本功能已经全部完成 。为了让用户操作起来更加方便,下面介绍为添加的辅助 

功能编写代码。  



     (3 )为附加功能编写代码  

     首先,当用户单击 List Box 控件中的某一表项时,在 DataGrid 控件中会相应地出现此表 

中所有的记录。当用户在 List Box 中单击一项时,会激发 LBN_SELCHANGE 消息,下面为 

此消息添加处理函数。打开“ClassWizard ”对话框,在“Class  name ”下拉菜单中选择 

CAdoTestView,在“Object Ids ”下拉列表中选择 IDC_LISTBOX,在“Messages ”下拉列表 

中选择 LBN_SELCHANGE ,单击“Add Function ”,采用默认的函数名,然后依次单击“OK ” 

和“Edit Code ”按钮,定位到函数 CAdoTestView::OnSelchangeListbox(),代码如下:  



     void CAdoTestView::OnSelchangeListbox()    



     {  



          // TODO: Add your control notification handler code here  



          //得到鼠标单击项在 List Box 中的索引值  



          int index = m_ListBox。GetCurSel();  



          //根据索引值得到表项的名字  



          m_ListBox。GetText(index; m_strTableName);  



          //构造 SQL 查询语句  



          m_strSQL = 〃select * from '〃 + m_strTableName + 〃'〃;  



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