vc中通过ADO操作数据库

准备工作

(1)、引入ADO类

  1. #import "c:\program files\common files\system\ado\msado15.dll" \
  2. no_namespace \
  3. rename ("EOF", "adoEOF")

(2)、初始化COM

在MFC中可以用AfxOleInit();非MFC环境中用:

  1. CoInitialize(NULL);
  2. CoUnInitialize();

(3)#import 包含后就可以用3个智能指针了:_ConnectionPtr、_RecordsetPtr和_CommandPtr

1.连接和关闭数据库

(1)连接

例子:连接Access数据库

  1. AfxOleInit();//初始化
  2. HRESULT hr;
  3. try
  4. {
  5. hr = m_pConnection.CreateInstance("ADODB.Connection");///创建Connection对象
  6. if(SUCCEEDED(hr))
  7. {
  8. m_pConnection->ConnectionTimeout = 0;
  9. hr = m_pConnection->Open( "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=db.mdb", "", "", adModeUnknown);
  10. //m_pConnection->PutDefaultDatabase ((_bstr_t)"DB"); //设置默认数据库
  11. m_pCommand.CreateInstance(__uuidof(Command));
  12. m_pCommand->CommandTimeout = 5;
  13. m_pCommand->ActiveConnection = m_pConnection;
  14. }
  15. }
  16. catch(_com_error e)///捕捉异常
  17. {
  18. CString errormessage;
  19. errormessage.Format(" 连接数据库失败! 错误信息:%s",e.ErrorMessage());
  20. AfxMessageBox(errormessage);///显 示错误信息
  21. }

(2)、关闭

  1. //如果数据库连接有效
  2. if( m_pConnection->State )
  3. m_pConnection->Close();
  4. m_pConnection = NULL;

(3)、设置连接时间

  1. //设置连接时间 -----------------------------------
  2. pConnection->put_ConnectionTimeout(long(5));

2.打开一个结果集

(1)打开,首先创建一个_RecordsetPtr实例,然后调用Open()得到一条SQL语句的执行结果

  1. _RecordsetPtr m_pRecordset;
  2. m_pRecordset.CreateInstance(__uuidof(Recordset));
  3. // 在ADO操作中建议语句中要常用 try...catch()来捕获错误信息,
  4. // 因为它有时会经常出现一些意想不到的错误。jingzhou xu
  5. try
  6. {
  7. m_pRecordset->Open("SELECT * FROM DemoTable",// 查询DemoTable表中所有字段
  8. m_pConnection.GetInterfacePtr(),  // 获取库接库的IDispatch指针
  9. adOpenDynamic,
  10. adLockOptimistic,
  11. adCmdText);
  12. }
  13. catch(_com_error *e)
  14. {
  15. AfxMessageBox(e->ErrorMessage());
  16. }

(2)关闭结果集

  1. m_pRecordset->Close();

3.操作一个结果集

(1)、遍历(读取)

a)、用pRecordset->adoEOF来判断数据库指针是否已经移到结果集的末尾了;m_pRecordset->BOF判断是否 在第一条记录前面:

  1. while(!m_pRecordset->adoEOF)
  2. {
  3. var = m_pRecordset->GetCollect("Name");
  4. if(var.vt != VT_NULL)
  5. strName = (LPCSTR)_bstr_t(var);
  6. var = m_pRecordset->GetCollect("Age");
  7. if(var.vt != VT_NULL)
  8. strAge = (LPCSTR)_bstr_t(var);
  9. m_AccessList.AddString( strName + " --> "+strAge );
  10. m_pRecordset->MoveNext();
  11. }

b)、取得一个字段的值的办法有两种办法

一是
  1. //表示取得第0个字 段的值
  2. rdset->GetCollect("Name");
  3. // 或者
  4. rdset->GetCollect(_variant_t(long(0));
二是
  1. pRecordset->get_Collect("COLUMN_NAME");
  2. //或者
  3. pRecordset->get_Collect(long(index));

(2)、添加

  1. 调用m_pRecordset->AddNew();
  2. 调用m_pRecordset->PutCollect();给每个字段赋值
  3. 调用m_pRecordset->Update();确认

(3)、修改

(4)、删除

a)、把记录指针移动到要删除的记录上,然后调用

  1. Delete(adAffectCurrent)
  2. try
  3. {
  4. // 假设删除第二条记录
  5. m_pRecordset->MoveFirst();
  6. m_pRecordset->Move(1);
  7. // 从0开始
  8. m_pRecordset->Delete(adAffectCurrent);
  9. // 参数adAffectCurrent 为删除当前记录
  10. m_pRecordset->Update();
  11. }
  12. catch(_com_error *e)
  13. {
  14. AfxMessageBox(e->ErrorMessage());
  15. }

4.直接执行SQL语句,除了要用到结果集其余的大部分功能都可以直接用SQL语言实现

(1)、用_CommandPtr和_RecordsetPtr配合

  1. _CommandPtr m_pCommand;
  2. m_pCommand.CreateInstance(__uuidof(Command));
  3. // 将库连接赋于它
  4. m_pCommand->ActiveConnection = m_pConnection;
  5. // SQL语句
  6. m_pCommand->CommandText = "SELECT * FROM DemoTable";
  7. // 执行SQL语句,返回记录集
  8. m_pRecordset = m_pCommand->Execute(NULL, NULL,adCmdText);

(2)、直接用_ConnectionPtr执行SQL语句

  1. _RecordsetPtr Connection15::Execute ( _bstr_t CommandText,
  2. VARIANT * RecordsAffected,
  3. long Options )

其中CommandText是命令字串,通常是SQL命令。

参数RecordsAffected是操作完成后所影响的行数,

参数Options表示CommandText中内容的类型,Options可以取如下值之一:

  • adCmdText:表明CommandText是文本命令
  • adCmdTable:表明CommandText是一个表名
  • adCmdProc:表明CommandText是一个存储过程
  • adCmdUnknown:未知

例子:

  1. _variant_t RecordsAffected;
  2. m_pConnection->Execute("UPDATE users SET old = old+1",&RecordsAffected,adCmdText);

5.调用存储过程

(1)、利用_CommandPtr

  1. _CommandPtrm_pCommand;
  2. m_pCommand.CreateInstance(__uuidof(Command));
  3. m_pCommand->ActiveConnection = m_pConnection;  // 将库连接赋于它
  4. m_pCommand->CommandText = "Demo";
  5. m_pCommand->Execute(NULL,NULL, adCmdStoredProc);

(2)、直接用_ConnectionPtr直接调用(见4.(2))

6.遍历数据库中的所有表名

  1. _ConnectionPtr m_pConnect;
  2. _RecordsetPtr pSet;
  3. HRESULT hr;
  4. try
  5. {
  6. hr = m_pConnect.CreateInstance("ADODB.Connection");
  7. if(SUCCEEDED(hr))
  8. {
  9. CString dd;
  10. dd.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s",file);
  11. hr = m_pConnect->Open((_bstr_t)dd,"","",adModeUnknown);
  12. pSet = m_pConnect->OpenSchema(adSchemaTables);
  13. while(!(pSet->adoEOF))
  14. {
  15. //获取表格
  16. _bstr_t table_name = pSet->Fields->GetItem("TABLE_NAME")->Value;
  17. //获取表格类型
  18. _bstr_t table_type = pSet->Fields->GetItem("TABLE_TYPE")->Value;
  19. //过滤一下,只输出表格名称,其他的省略
  20. if ( strcmp(((LPCSTR)table_type),"TABLE")==0){
  21. CString tt;
  22. tt.Format("%s",(LPCSTR)table_name);
  23. AfxMessageBox(tt);
  24. }
  25. pSet->MoveNext();
  26. }
  27. pSet->Close();
  28. }
  29. m_pConnect->Close();
  30. }catch(_com_error e)///捕捉异常
  31. {
  32. CString errormessage;
  33. errormessage.Format("连接数据库失败!rn错误 信息:%s",e.ErrorMessage());
  34. AfxMessageBox(errormessage);
  35. return -1;
  36. }

7.遍历一个表中的所有字段

  1. Field *  field = NULL;
  2. HRESULT  hr;
  3. Fields *  fields = NULL;
  4. hr = m_pRecordset->get_Fields (&fields);//得到记录集的字段集和
  5. if(SUCCEEDED(hr))
  6. fields->get_Count(&ColCount);
  7. //得到记录集的字段集合中的字段的总个数
  8. for(i=0;i ...
  9. Item[i]->get_Name(&bstrColName);//得到记录集//中的字段名
  10. strColName=bstrColName;
  11. nameField = strColName;
  12. m_FieldsList.AddString(nameField);
  13. }
  14. if(SUCCEEDED(hr))
  15. fields->Release();//释放指针

附:

1、_variant_t

(1)、一般传给这3个指针的值都不是MFC直接支持的数据类型,而要用_variant_t转换一下

_variant_t(XX)可以把大多数类型的变量转换成适合的类型传入

(2)、_variant_t var;

_variant_t -> long: (long)var;

_variant_t -> CString: CString strValue = (LPCSTR)_bstr_t(var);

CString -> _variant_t: _variant_t(strSql);

2、BSTR宽字符串与CString相互转换

BSTR bstr;

CString strSql;

CString -> BSTR: bstr = strSql.AllocSysString();

BSTR -> CString: strSql = (LPCSTR)bstr;

3、_bstr_t与CString相互转换

_bstr_t bstr;

CString strSql;

CString -> _bstr_t: bstr = (_bstr_t)strSql;

_bstr_t -> CString: strSql = (LPCSTR)bstr;

4、关于时间

Access:表示时间的字符串#2004-4-5#

Sql:表示时间的字符串‘‘2004-4-5‘‘

DateField(时间字段)

select * from my_table where DateField > #2004-4-10#

try

{

m_pCommand->CommandText = "INSERT INTO tTest(age) VALUES(‘23f2‘) ";

m_pRecordset = m_pCommand->Execute(NULL,NULL, adCmdText);

}

catch(_com_error e)///捕捉异常

{

CString errormessage;

errormessage.Format("连接数据库失败! 错误信息:%s",e.ErrorMessage());

AfxMessageBox(errormessage);///显示错误信息

}

时间: 2024-10-21 12:43:36

vc中通过ADO操作数据库的相关文章

VC++中使用ADO方式操作ACCESS数据库

ADO(ActiveX Data Object)是Microsoft数据库应用程序开发的新接口,是建立在OLE DB之上的高层数据库访问技术,即使你对OLE DB,COM不了解也能轻松对付ADO,因为它非常简单易用,甚至比你以往所接触的ODBC API.DAO.RDO都要容易使用,并不失灵活性.本文详细地介绍在Visual C++开发环境下如何使用ADO来进行数据库应用程序开发,并给出示例代码.为了使读者朋友都能测试本例提供的代码,我们采用Access数据库,您可以直接在我们提供的示例代码中找到

用ADO操作数据库的方法步骤(ZT)

http://www.cppblog.com/changshoumeng/articles/113437.html 学习ADO时总结的一些经验 用ADO操作数据库的方法步骤 ADO接口简介 ADO库包含三个基本接口:_ConnectionPtr接口._CommandPtr接口和_RecordsetPtr接口. _ConnectionPtr接口返回一个记录集或一个空指针. 通常使用它来创建一个数据连接或执行一条不返回任何结果的SQL语句,如一个存储过程.使用_ConnectionPtr接口返回一个

用ADO操作数据库的方法步骤

用ADO操作数据库的方法步骤 学习ADO时总结的一些经验 - 技术成就梦想 - 51CTO技术博客 http://freetoskey.blog.51cto.com/1355382/989218 ADO接口简介 ADO库包含三个基本接口:_ConnectionPtr接口._CommandPtr接口和_RecordsetPtr接口. _ConnectionPtr接口返回一个记录集或一个空指针. 通常使用它来创建一个数据连接或执行一条不返回任何结果的SQL语句,如一个存储过程.使用_Connecti

在.NET中调用DataWindow操作数据库

Sybase在2004/1/19日推出了Pb 10 beta1版本,其中包含DataWindow.NET 1.0,这真是一个另人兴奋的消息! 在PB市场日益萎缩的今天,在.NET大行其道的今天Sybase公司终于推出了DataWindow.NET,它支持DataWindow绝大部份原有事件和属性,PB技术终于可以重新又派上用场了!! 下过来安装程序,便急不可待的在VS.NET2003下面做了一个简单的例子,发现真的很好用!源代码.界面如下: using System; using System.

MFC中使用ADO进行数据库操作

参考FROM:http://hi.baidu.com/sunkanghome/item/e1fda510b3186359f1090ee2 数据库与数据库编程: 当前各种主流数据库有很多,包括Oracle, MS SQL Server, Sybase, Informix, MySQL, DB2, Interbase / Firebird, PostgreSQL, SQLite, SAP/DB, TimesTen, MS ACCESS等等. 数据库编程是对数据库的创建.读写等一列的操作.数据库编程分

在PHP中使用Mysqli操作数据库

PHP的 mysqli 扩展提供了其先行版本的所有功能,此外,由于 MySQL 已经是一个 具有完整特性的数据库服务器 , 这为PHP 又添加了一些新特性 . 而 mysqli 恰恰也支持了 这些新特性. 一. 建立和断开连接 与 MySQL数据库交互时,首先要建立连接,最后要断开连接,这包括与服务器连接并 选择一个数据库 , 以及最后关闭连接 .与 mysqli 几乎所有的特性一样 , 这一点可以使用面向 对象的方法来完成,也可以采用过程化的方式完成. 1. 创建一个 mysqli 的对象 $

使用spring boot中的JPA操作数据库

前言 Spring boot中的JPA 使用的同学都会感觉到他的强大,简直就是神器一般,通俗的说,根本不需要你写sql,这就帮你节省了很多时间,那么下面我们来一起来体验下这款神器吧. 一.在pom中添加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </depen

【Springboot】springboot中使用mybatis操作数据库

新建springboot项目的时候,选择好web,mybatis,JDBC 在application.properties或者application.yml中配置 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/studentManagerBoot?useUnicode=true&characterEncoding=utf-8&useSSL=tr

Visual C++中的ADO编程

摘  要:本文介绍了微软推出的以ActiveX技术为基础的ADO数据存取技术,分析了ADO的工作原理,并用Visual C++说明了ADO数据访问技术的实现方法. 关键字:ADO:连接对象:OLE DB:数据存取:记录集 ADO(ActiveX Date Object)是Microsoft数据库应用程序开发的新接口,是建立在OLE DB之上的高层数据库访问技术.ADO 技术基于COM(Component Object Model),具有COM组件的诸多优点,可以用来构造可复用应用框架,被多种语言