ADO访问数据库

大致操作过程:

_Connectionptr : CreateInstance , Open , ... Close , Realse

_CommandPtr : CreateInstance , ActiveConnection , CommandText , Excute , ... Close , Realse

_RecordsetPtr : CreateInstance , GetCollect 、Move(MoveNext,MoveFirst)、AddNew、PutCollect、Update , ... Close , Realse

ODBC方式链接。

1、应用程序的stdafx.h头文件中(也可以在其他合适的地方)包含如下语句。

#import "C://program files//commonfiles//system//ado//msado15.dll" no_namespacerename ("EOF","adoEOF")

2、链接数据库

CoInitialize(NULL);                                          //初始化Com组件
_ConnectionPtr conPtr;                                      //数据库链接指针
     //conPtr.CreateInstance("ADODB.Connection");           //Connection用于与数据库服务器的链接
     conPtr.CreateInstance(__uuidof(Connection));            //Connection用于与数据库服务器的链接另一种方式
     /******************连接数据库********************/
     try
     {
         conPtr->ConnectionTimeout = 5;                          //设置连接时间
         // MySqlTest为数据源名 localhost表示本地root表示用户名 sa表示密码
         //链接方式1,使用这种方式链接时要注意在设置数据源时一定要选择一个数据库
         //conPtr->Open("DSN=MySqlTest;server=localhost;","root","sa",adModeUnknown);///连接MySql数据库(测试成功)
         //链接方式2采用这种方式链接时在创建数据源时没有必要选择一个数据库          conPtr->Open("DSN=MySqlTest;server=localhost;database=test;","root","sa",adModeUnknown);///连接MySql数据库(测试成功)
     }
     catch(_com_error e)                                              //捕捉异常
     {
         AfxMessageBox(e.ErrorMessage());
     } 
     CoUninitialize();                                       //释放com组件//不知是否有必要

3、访问数据库

_RecordsetPtr recordPtr;//数据集指针
recordPtr.CreateInstance(__uuidof(Recordset));
CString cmdStr=_T("selectname,stuno from student");//student为表名 该表中有两个字段name(字符型)stuno(int型)
     try
     {
              recordPtr->Open(_variant_t(cmdStr),
              conPtr.GetInterfacePtr(), 
              adOpenDynamic, 
              adLockOptimistic, 
              adCmdText); 
     }
     catch(_com_error e)
     {
         AfxMessageBox(e.Description());
     }
     while(!(recordPtr->adoEOF))
     {//获取记录
         CStringname=(CString)recordPtr->GetCollect(_variant_t("name")).bstrVal;
         intno=recordPtr->GetCollect(_variant_t("stuno")).intVal;
         recordPtr->MoveNext();
     }
     recordPtr->Close();//关闭记录集
     recordPtr.Release();//释放空间
     conPtr->Close();//关闭连接
     conPtr.Release();//释放空间

非ODBC方式链接。

链接数据库

CoInitialize(NULL);                                          //初始化Com组件
_ConnectionPtr conPtr;                                       //数据库链接指针
     //conPtr.CreateInstance("ADODB.Connection");            //Connection用于与数据库服务器的链接
     conPtr.CreateInstance(__uuidof(Connection));            //Connection用于与数据库服务器的链接另一种方式
// MySQL ODBC 5.1 Driver为驱动名称(取决于我们为MySql安装的驱动),localhost为服务器地址,test为数据库名,root为用户名(MySql默认用户名为root),sa为密码
     CStringconStr=_T("Driver={MySQL ODBC 5.1 Driver };Server= localhost;Database=test;");
     /******************连接数据库********************/
     try
     {
         conPtr->ConnectionTimeout = 5;                          //设置连接时间
         conPtr->Open((_bstr_t)conStr, _T("root"),_T("sa"), adModeUnknown);
     }
     catch(_com_error e)                                              //捕捉异常
     {
         AfxMessageBox(e.ErrorMessage());
     } 
     CoUninitialize();                                       //释放com组件

获取记录集

获取记录集的方式与ODBC方式相同

只要是在自己的电脑上对udl进行了连接测试成功后,在用记事本(如若不行,直接把文件的扩展名udl改成txt)打开这个文件,你会发现里面就写着自己电脑的数据库连接字符串!!!这都是网上别人的成果!!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏bboysoul

kali工具-DNSenmum

首先下载 git clone https://github.com/fwaeytens/dnsenum.git 根据里面的INSTALL.txt来安装 首...

591
来自专栏林德熙的博客

win10 uwp 如何拖动一个TextBlock的文字到另一个TextBlock

我在堆栈网看到有人问 如何拖动一个TextBlock的文字到另一个TextBlock 于是看到一个大神给出的方法,下面我就来和大家说下如何拖动

391
来自专栏進无尽的文章

扒虫篇-Bug日志Ⅳ

解决办法:other linker flag -ObjC 造成的,有些时候设置other linker flag 为-ObjC会出现多次导入的报错。

531
来自专栏拂晓风起

Loader拉取图片,由于redirect重定向,导致策略文件无效 设置checkPolicyFile后还是无效:需要一个策略文件,但在加载此媒体时未设置 checkPolicyFile 标志

936
来自专栏wOw的Android小站

[Android] 针对生成的图片文件在系统Gallery不显示的处理

  之前遇到过一个问题,就是发现我在程序中生成一个新的 Bitmap 之后,当我打开系统的 Gallery 查看时,并没有看到新生成的图像。然而打开文件浏览器,...

471
来自专栏程序员互动联盟

【专业技术】Android如何保证安全?

存在问题: 那么多小伙伴想root,root后好处多多你懂的,那么开发的小伙伴最想关心的是安全机制问题。 解决方案: 我们就以此来了解一下Android 安全...

3636
来自专栏逆向技术

为异常处理做准备,熟悉一下WinDbg工具

            为异常处理做准备,熟悉一下WinDbg工具 马上开始异常处理第二讲,但是在讲解之前,还有熟悉一下我们的WinDbg工具,当然你如果熟悉这...

1909
来自专栏老安的博客

vmware api开发之html5的虚拟机console

1464
来自专栏debugeeker的专栏

《coredump问题原理探究》windows版5.4节联合体

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xuzhina/article/detai...

331
来自专栏C#

创建基于MailKit和MimeKit的.NET基础邮件服务

       邮件服务是一般的系统都会拥有和需要的功能,但是对于.NET项目来说,邮件服务的创建和使用会较为的麻烦。.NET对于邮件功能提供了System.Ne...

3925

扫码关注云+社区