使用ADO封装类的数据库程序开发实例(下)

五、开始编写ADO应用程序.

使用ADO之前,我们另外还需要添加下面的语句,如此把ADO的库引入到工程中

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

根据机器安装时候的设置不同具体的路径可能不一样。

另外编译的时候会出现如下的警告信息:

msado15.tlh(405) : warning C4146: unary minus operator applied to unsigned type, result still unsigned

MSDN建议我们不要理会。如果你实在不想看到的话可以在stdafx.h中加入一行下面的代码:

#pragma warning(disable:4146)

这样这个警告信息就不会再出现了。

ADO使用了COM,所以在使用ADO之前,必须对COM进行了初始化,否则无法使用.你可以使用AfxOleInit()来初始化,但只能初始一次,你不能多次调用此函数,建议你在应用程序的APP类的InitInstance方法中进行初始化.

上面这些一般相关的资料都有详细说明,因此我就不细说了,下面我们来看看如何我封装的两个类。

六、ADO封装类:CAdoConnection 和 CAdoRecordSet

首先当然是要连接到数据源了,连接到数据源的函数是_CAdoConnection的Connect方法,它封装了ADO连接对象的CreateInstance和Open方法:

我们来看看我是如何封装的:

BOOL CAdoConnection::Connect(LPCTSTR strConnect, long lOptions)
{
  m_strConnect = strConnect;
  try
  {
    ///创建 Connection 对象---------------------------
    HRESULT  hr = m_pConnection.CreateInstance("ADODB.Connection");
    if (SUCCEEDED(hr))
    {
      // 连接数据库---------------------------------------------
      if (SUCCEEDED(m_pConnection->Open(strConnect, "", "", lOptions)))
      {  
        return TRUE;
      }
    }
  }
  catch (_com_error e)
  {
    TRACE(_T(":( 连接数据库发生错误: %s\n"), e.ErrorMessage());
    return FALSE;
  }
  catch (...)
  {
    TRACE(_T(":( 连接数据库时发生未知错误:"));
  }
  return FALSE;
}

使用之前先定义一个CAdoConnection 类对象如m_adoConnection,例如:

CString strSrcName = "E:\\Access\\datebase.mdb";//假设在e盘有这样一个access的数据库文件
CString strConnect = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + strSrcName;
m_adoConnection.Connect(LPCSTR(strConnect));

这样就连接到数据源了.

接着就是要打开记录集了,下面我对它的open方法的封装:使用进你可以忽略后面的三个参数,直接把一个SQL语句传给它.

HRESULT CAdoRecordSet::Open(LPCTSTR strSQL,
      long lOption,
      CursorTypeEnum CursorType,
      LockTypeEnum LockType)
{
  try
  {
    if (m_pConnection == NULL)
    {
      return -1;
    }
    else if (m_pRecordset == NULL)
    {
      m_pRecordset.CreateInstance("ADODB.Recordset");
    }
    
    m_pRecordset->Open(_bstr_t(strSQL),
      _variant_t((IDispatch*)m_pConnection->GetConnection(), true),
      CursorType, LockType, lOption);
    if (m_pRecordset == NULL)
    {
      return -1;
    }
    return (m_pRecordset->adoEOF) ? 0 : 1;
  }
  catch (_com_error e)
  {
    TRACE(_T(":( 打开记录集发生错误: %s\n"), e.ErrorMessage());
    return -1;
  }
}

例如我们可以这样来用:CAdoRecordSet rset;
rset.SetAdoConnection(&(GetDocument()->m_adoConnection));//记得要先指定相应的连接对象,否则会出错.
m_strSQL = "select * from city";//要执行的SQL语句.
rset.Open(m_strSQL);

时间: 2024-10-26 06:57:38

使用ADO封装类的数据库程序开发实例(下)的相关文章

使用ADO封装类的数据库程序开发实例[第二版](上)

从上次在VC知识库发表<使用ADO封装类的数据库程序开发实例>一文后,得到许多网友的响应,甚觉欣慰.但由于我对ADO也非完全精通,所以上次写的类很不完美,甚至可能给某些朋友带来麻烦,因此一直想把它写得更完善一点. 现在写的这个类功能应该说比较完善了,基本上封装了ADO组件的大部分方法,并扩展了一些人们常用到的方法,如把文件或图片写到数据库中,从数据库中读出位图字段,字段的值的智能转换等等. 因为实在是时间不够,我几乎没有对command类做任何有效的测试,也没有写相关的文档,而对connect

使用ADO封装类的数据库程序开发实例(上)

源代码运行效果图如下: 开发实例(上)-vc数据库编程实例ado"> 一.前言 用过ADO的人都知道, 调用ADO要处理很多"麻烦"的事情,如异常处理等,要写很多try - catch块. 有点不甚其烦.我干脆把常用的函数都封装起来,免去老是要写try - catch块的麻烦.做起来虽然没有什么技术含量,但也比较烦琐,所以只完成了一部分,且由于时间及个人水平有限,没有对封装的东西作全面测试,并必定有很多错误,但想到对某些朋友可能有用.所以先"捐"出来

使用ADO封装类的数据库程序开发实例[第二版](下)

CAdoRecordSet class: CAdoRecordSet: CAdoRecordSet::CAdoRecordSet() CAdoRecordSet::CAdoRecordSet(CAdoConnection *pConnection) void CAdoRecordSet::SetAdoConnection(CAdoConnection *pConnection) 创建Connection对象. Params: [pConnection]: 连接对象指针. Open 方法: BOO

现流行数据库程序开发工具的比较分析

比较|程序|数据|数据库 [程序开发系列一]现流行数据库程序开发工具的比较分析 武汉华中师大信管系 谢刚 摘要:随着计算机技术不断发展,各种数据库编程工具也随着发展,使当今的大多数程序开发人员可以摆脱枯燥无味的用计算机指令或汇编语言开发软件,而是利用一系列高效的.具有良好可视化的编程工具去开发各种数据库软件,从而达到事半功倍的效果,但是现在市面上的数据库编程工具门类众多,优良不齐,比如VB,VC,DEPHI,PB等,对此我特别针对流行的开发语言介绍相应的较为成熟的数据库编程工具. 关键字:数据库

基于SharpMap扩展程序开发实例

SharpMap是基于.Net平台开发的GIS地图渲染组件.在SharpMap的内部设计了基于OGC 标准的几何模型 构架,设计了IProvider策略模式的多源矢量地图数据适配器接口,地图要素渲染的底层主要通过几何变 换将Geometry转换为.Net支持的几何模型如System.Drawing.Point.System.Drawing.Rectangle. System.Drawing.Drawing2D.GraphicsPath等,然后调用System.Drawing.Graphics类的

《电子尺》V1.02程序开发实例

程序功能 有时在制作网页或一些多媒体时,需要插入一些自制的图片和flash动画,在制作之前一定需要先确定图片的高和宽,用这个软件就可以轻松的量出你所需要的高和宽. 总体介绍 程序在开始测量时要锁定整个屏幕,包括任务栏等.原先计划利用钩子(Hook)来截取所有的鼠标消息,实现屏幕的锁定.但是无论使用WH_MOUSE或WH_GETMESSGAE都无法完全截获所有消息.所以我就利用了一个占据整个屏幕的透明窗口来实现.虽然是透明的窗口,但是一旦窗口创建以后,实际屏幕的更新就不会再对窗口中显示的内容进行影

关于java RMI分布式程序开发实例

关于java RMI分布式程序开发实例   作者: javaboy2012 Email:yanek@163.com qq:    1046011462   一. 服务器端     接口定义:注意必须继承Remote接口 package com.yanek.rmi.server; import java.rmi.Remote; import java.rmi.RemoteException; import java.util.List; public interface ChannelManage

微信小程序开发实例详解_其它综合

"小程序"破解IDE + Demo:https://github.com/gavinkwoe/weapp-ide-crack.git 资源汇总:https://github.com/Aufree/awesome-wechat-weapp 官方简易教程·MINA:http://wxopen.notedown.cn/ Hello小程序 - 非官方:http://www.helloxcx.com 微信应用号开发教程:https://my.oschina.net/wwnick/blog/750

Android数据库程序开发必备工具SqliteDev

找了一晚,终于让我找到了Sqllite数据库管理工具,先介绍下Sqllite数据库: 什么是 sqlite ? sqlite 是一款轻量级的.基于文件的嵌入式数据库,2000年就已经诞生,经过7年多的发展,直到今天已经成为最流行的嵌入式数据库,包括google在内的公司在其桌面软件中亦使用 sqlite 存储用户数据.由此可以看出,已经没有任何理由去怀疑sqlite的稳定性了. sqlite的优势? 1. 免配置,和access一样,只要把数据库文件通过ftp上传到服务器上就可以使用,不需要服务