读写数据库的技术很多,现在多用ADO。ADO以COM方式提供,所以它的很多行为遵循COM规范。首先,要引入ADO的COM文件,它的位置一般在"C:/Program Files/Common Files/System/ado/msado15.dll"。

1. 引入ADO

打开预编译头文件StdAfx.h,写上引入声明:

#import "C:/Program Files/Common Files/System/ado/msado15.dll" no_namespace rename("EOF","adoEOF")

解释一下上句:no_namespace是指忽略命名空间,rename则是把ADO中的EOF重命名为adoEOF。命成什么名字无所谓,但注意声明中的名字要和代码中的名字一致。

2. 初始化

用ADO写代码前,要将COM初始化。常用手段是在代码前后加上CoInitialize(NULL)和CoUninitialize()。也可以用AfxOleInit()来初始化COM库。

3. 三个核心对象

ADO的3个核心对象是连接对象(_Connection)、命令对象(_Command)和记录集对象(_RecordSet)。其中连接对象是任何操作必须的。很多操作3个核心对象都可以完成。要实例化它们并使用它们提供的方法,不得不说到它们是一种智能指针(Smart Pointer)。在初始化或释放等操作时,它们是一个对象,用点操作符,其他大部分操作则使用“->”操作符。

4. 实例化

_ConnectionPtr pConn(__uuidof(Connection));

_RecordsetPtr pRec(__uuidof(Recordset));

_CommandPtr pCmd(__uuidof(Command));

如果上面不加参数,则需加上:

pConn.CreateInstance("ADODB.Connection");

pRec.CreateInstance("ADODB.Recordset");

pCmd.CreateInstance("ADODB.Command");

5. 连接数据库

连接数据库一般采取字符串连接。这个字符串的获取方法用了“不能说的秘密”,即任意新建一个txt文件,重命名为.x.udl。然后双击此文件,将出现“数据库连接属性”窗口。第一个标签页“提供程序”列出了所有数据库引擎,Access, SQL Server, Oracle等,选择后点下一步跳至第二个标签页“连接”,选择服务器名称栏可以填上服务器的IP地址,本机则可不填或填点号;填上数据库用户名和密码后就可以选择数据库了。点“测试连接”按钮,成功。确定。用记事本打开x.udl。将会看到它生成的连接字符串。如下:

"Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Password=123;Initial Catalog=cfdata"

此连接串中,Persist Security Info属性为True时表示在建立连接后仍然保存密码,一般取False即可。ID和Password属性只有在上述数据库属性对话框中勾选“允许保存密码”时才会有。自己可以手工添加。Cfdata是我的数据库名。

C++中连接代码如下:

pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Password=123;Initial Catalog=cfdata";

6. 示例

有些数据库操作_Connection一个就能完全搞定。如update语句。因为它不需要返回的结果。如下:

pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Password=123;Initial Catalog=cfdata";

pConn->Open("","","",adConnectUnspecified);   //打开连接。此处参数均已在上述字符串声明,故可为空

CString strSQL="update table1 set name=’Richard’ where id=1";

_pConn->Execute(_bstr_t(strSQL),NULL,adCmdText);

这里涉及强制类型转换。COM中的数据类型和常规(如MFC)类型一般都有对应,但需要转换。如上面的_bstr_t和CString。至于应该转换成什么类型,看VC环境中的提示即可(这里推荐大家加装Visual Assitant,使提示功能更完善)。

也有些操作需要返回记录集,如select语句。这里就至少需要_Connection和_Recordset两种核心对象,也可以用_Command执行之。下面展示同一操作用3种对象分别实现的代码。

(1)连接对象

CString strSQL="select * from table1";     //方法1

pRec=pConn->Execute(_bstr_t(strSQL),NULL,adCmdText);

(2)记录集对象

CString strSQL="select * from table1";           //方法2

pRec->Open(_variant_t(strSQL),(_variant_t)( (IDispatch*)pConn),adOpenDynamic,adLockOptimistic,adCmdText);

其中第二个参数(_variant_t)( (IDispatch*)pConn)指明活动连接,数据类型转换比较复杂,_variant_t是参数要求的类型,IDispath*则是_variant_t可强制转换类型类型。也可用下句:

pConnGetInterfacePtr();

(3) 命令对象

CString strSQL="select * from table1";         //方法3

pCmd->put_ActiveConnection((_variant_t)((IDispatch*)pConn));

pCmd->CommandText=_bstr_t(strSQL);

pRec=pCmd->Execute(NULL,NULL,adCmdText);

7. 数据使用

取得记录集后,将其中数据取出。用一个ListBox读取其中name字段数据。代码如下:

while(!pRec->adoEOF)

{

//_bstr_t类型可以视作COM类型字符串和MFC类型字符串之间的桥梁

CString str=LPSTR(_bstr_t(pRec->GetCollect("name")));

((CListBox*)GetDlgItem(IDC_LIST1))->AddString(str);

pRec->MoveNext();

}

上述代码中用到了adoEOF,要注意直接拷贝第三方代码时可能会被重命名为rsEOF等,此时则需作相应更改。另外,while循环中的MoveNext()也不要忘了,否则它就成了死循环了。字段值的获取及转换也可用下面方法:

_variant_t var=pRec->GetCollect("name");

var.ChangeType(VT_BSTR);

CString str=var.bstrVal;

8. 关闭与释放

用完相应对象后,需要关闭并释放之,代码如下:

pRec->Close();

pConn->Close();

pRec.Release();

pCmd.Release();

pConn.Release();

9. 错误捕获

数据库操作难免出现错误,连接串错误,SQL语句错误,或返回NULL你却硬要向表里塞(此错误可以在取出后用var.vt!=VT_NULL判断),所以我们需要把它们放到try…catch段中。ADO在捕获到错误后会抛出_com_error类型异常,我们可以这样做:

try

{

pConn->ConnectionString="Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Password=123;Initial Catalog=cfdata";

pConn->Open("","","",adConnectUnspecified);

…………   //代码省略

}

catch(_com_error& e)

{

AfxMessageBox(e.ErrorMessage());

AfxMessageBox(e.Description());

}

这里有个疑惑,在捕获错误后,e.ErrorMessage()和e.Description()中放着不同信息,有时前者说得清晰,有的后者说的清晰,搞不清楚,索性就都加上吧。最后,可以再加个catch(…),毕竟ADO之外的地方也可能发生错误。

这里,我还犯过一个错误,被它整了N久。我把_com_error& e写成了_com_error* e后面也对应改成->操作符,而且编译通过,结果一运行程序就崩溃,而且它不告诉我在哪出错,因为这时的错误是_com_error这时却对着_com_error*来捕获当然捕不到。这里&只是一个引用,写不写无所谓,*是万万不可地。(网上书上很多大师级代码都是用了*,误导啊)。

10. 其他接口

ADO中除了3个核心对象外,我们还应了解FieldsPtr、FieldPtr、StreamPtr等接口。例如上述示例中,我们可以用FieldsPtr的GetCount()方法获取其字段个数,用FieldPtr来接收具体字段等。二进制数据如图像文件等则会用到StreamPtr。

实例代码:

#include <iostream>

#include "vector"

#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","adoEOF")

using namespace std;

int main(int argc, char* argv[])

{

CoInitialize(NULL);

_ConnectionPtr pConn(__uuidof(Connection));

_RecordsetPtr pRec(__uuidof(Recordset));

或者采用以下方式:

//_ConnectionPtr pConn=NULL;

//_RecordsetPtr pRec=NULL;

//_CommandPtr pCmd=NULL;

//pConn->CreateInstance("ADODB.Connection");

//pRec->CreateInstance("ADODB.Recordset");

//pCmd->CreateInstance("ADODB.Command");

try

{

_bstr_t strConnect = "Provider=SQLOLEDB;Persist Security Info=True;\

User Id=sa;Password=123456;Initial Catalog=Test;Data Source=localhost";

//_bstr_t strConnect = "Provider=SQLOLEDB;Server=localhost;DataBase=Test;uid=sa;pwd=123456";

pConn->Open(strConnect,"","",adModeUnknown);

}

catch(_com_error &e)

{

cout<<"Initial failed!"<<endl;

cout<<e.Description()<<endl;

cout<<e.HelpFile()<<endl;

return 0;

}

try

{

pRec = pConn->Execute("select * from CorrespondField",NULL,adCmdText);

if(!pRec->BOF)

{

pRec->MoveFirst();

}

else

{

cout<<"Data is empty!"<<endl;

return 0;

}

vector<_bstr_t> column_name;

for(int i=0;i<pRec->Fields->GetCount();i++)

{

cout<<pRec->Fields->GetItem(_variant_t((long)i))->Name<<" ";

column_name.push_back(pRec->Fields->GetItem(_variant_t((long)i))->Name);

cout<<endl;

}

while(!pRec->adoEOF)

{

for(vector<_bstr_t>::iterator Itr = column_name.begin();Itr!=column_name.end();Itr++)

{

if (pRec->GetCollect(*Itr).vt != VT_NULL)

{

cout<<(_bstr_t)pRec->GetCollect(*Itr)<<" ";

}

else

{

cout<<"NULL"<<endl;

}

}

pRec->MoveNext();

cout<<endl;

}

}

catch (_com_error &e)

{

cout<<e.Description()<<endl;

cout<<e.HelpFile()<<endl;

return 0;

}

try

{

pRec->Close();

pConn->Close();

pRec->Release();

pConn->Release();

}

catch(_com_error &e)

{

cout<<e.Description()<<endl;

cout<<e.HelpFile()<<endl;

return 0;

}

CoUninitialize();

return 0;

}

ADO 访问数据库常见方法相关推荐

  1. VC用ADO访问数据库全攻略  作者 相生昌

    VC用ADO访问数据库全攻略 作者 相生昌 <script language=VBScript> document.title="VC用ADO访问数据库全攻略 "&am ...

  2. 用Mysql网页式管理工具安全地访问数据库的方法

    2019独角兽企业重金招聘Python工程师标准>>> 用Mysql网页式管理工具安全地访问数据库的方法 在使用通达OA系统时很多用户需要借助Mysql网页式管理工具进入后台数据库去 ...

  3. VC用ADO访问数据库全攻略

    一.ADO概述 ADO是Microsoft为最新和最强大的数据访问范例 OLE DB 而设计的,是一个便于使用的应用程序层接口.ADO 使您能够编写应用程序以通过 OLE. DB 提供者访问和操作数据 ...

  4. jython mysql_jython 访问数据库的方法

    jython 访问数据库 基本上有2个方法, 使用 zxJDBC (符合Python DB API2.0规范), 或者直接使用JDBC. 先写点dbexts, dbexts是zxJDBC作者写的一个扩 ...

  5. python访问数据库统一方法_Python 3.x 连接数据库(pymysql 方式)

    参考:http://www.cnblogs.com/woider/p/5926744.html ==================pymysql=================== 1.PyMyS ...

  6. MongoDB 3.0+访问数据库的方法

    今天用了mongoDB 3.5的开发包,发现以前熟悉的getDB等方法都被废弃了.查看官网的教程,现在可以用这种方法访问: MongoCredential credential = MongoCred ...

  7. ado mfc mysql_MFC 中用ADO访问数据库

    个人觉得,数据库操作连接和操作上手很快,但是那些类型总是会让你头疼 目前我还没搞清楚用怎么从T-SQL 的decimal技术到MFC中相应的数据?? 将一下数据库连接的步骤 一:加载动态链接库 #im ...

  8. c++使用ado访问数据库

    首先在stdafx.h中包含 #import "C:/Program Files (x86)/Common Files/System/ado/msado15.dll" no_nam ...

  9. 使用ADO或ADO控件访问数据库

    目录: 1.数据库的基础知识以及创建Access数据库 2.数据库的接口 3.使用ADO或ADO控件访问数据库 上篇文章,为大家讲解了数据库的接口,大家对ADO也有了较为基础的了解,这篇文章主要解决大 ...

  10. VC访问数据库学习总结

    VC连接数据库方式 目前Windows系统上常见的数据库接口包括: ODBC(开放数据库互连):访问数据库得先配置数据源 MFC(Microsoft基础类)ODBC类 DAO(数据访问对象) RDO( ...

最新文章

  1. 1.4 w字,25 张图让你彻底掌握分布式事务原理
  2. Mybatis ResolverUtil的设计概念
  3. python有效变量名_Python变量命名规则
  4. 果园机器人是什么文体_果园机器人课文原文
  5. git.exe init#timeout = 10错误:克隆远程repo'origin'时出错hudson.plugins.git
  6. C++ ::什么意思
  7. 第一章 Android Framework 基础认知
  8. 多个excel工作簿合并_EXCEL2016中如何快速合并多个工作簿中内容到一个工作表
  9. 金融货币学笔记(米什金)第三章 什么是货币 带原书总结
  10. branch什么意思中文翻译_汽车ABS是个啥?它有什么作用?
  11. 【硬件】在Windows PC端使用adb工具无线向电视机顶盒安装第三方软件(不需要ROOT,已解决)
  12. php输出白天时间,php 判断白天黑夜
  13. Flutter技术与实战(4)
  14. java关键字super指什么_java 关键字super详解及用法
  15. 亚马逊Amazon数据集
  16. webAPP开发三:实现数据的交互显示
  17. 差速齿轮原理_浅析限滑差速器的功用及工作原理
  18. 华为S9306 如何进行访问控制配置
  19. 【USB】Zadig 工具的使用说明与下载
  20. 允许 流程 强制收回

热门文章

  1. Rocketmq技术分享
  2. stream rabbit
  3. Apache Struts2高危漏洞(S2-057CVE-2018-11776)
  4. iOS Unicode转中文(UTF-8)
  5. SQL Server 填充因子
  6. 大数据与云计算学习:数据分析(一)
  7. javascript div z-index, input tabindex属性说明
  8. 语录帝——要想人前显贵,必须背地里遭罪
  9. 用VS.NET 2005制作安装程序
  10. 微信小程序登录后跳转tabbar页面