`
kevinhrw
  • 浏览: 188671 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

VC下ADO数据库操作的封装类

    博客分类:
  • C++
c 
阅读更多
/******************************************************************
模块名称:数据库操作类;
实现功能:提供接口,实现数据的索引,和操作。
研究人员:长寿梦;
最后更新:2010-05-12

预先操作:
【1】在stdafx.h中添加
    #import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
【2】在主进程的InitInstance()中添加
         if(!AfxOleInit())
        {
         AfxMessageBox("OLE初始化错误");
         return FALSE;
         }

【3】在.cpp文件中要包含"CPFile.h"
*********************************************************************/

/*****************************************************************
CPFile.h
******************************************************************/
class CPData 
{
public:
   
    //默认初始化构造函数
    CPData();
   
    //传入连接的构造函数
    CPData(_ConnectionPtr pConnection);
   
    //析构函数
    virtual ~CPData();
public:
   
    //连接数据库
    BOOL Connect(CString strUser,CString strPassword,CString strFileName="ConnectionParam.udl",int nOptions=-1,CString strConStr="Provider=sqloledb.1;Data Source=(local);Database=VLan");
   
    //关闭数据库的连接
    void DisConnect();
   
    //数据库查询语句,用来对数据库的各种字段进行查询
    //如果成功返回TRUE,否则返回FALSE.查询的结果存储在类的共有成员变量m_pRecordset中
    //查询结果的行数和列数分别保存在共有成员变量m_nResultRow和m_nResultCol中
    BOOL Select(CString strSql);
   
    //查询语句,负责对仅仅查询一个字段的情况进行处理
    //结果存放在CStringArray类型的变量pResult中
    BOOL Select(CString strSql,CStringArray& Result);
   
    //对多个字段进行查询
    BOOL SelectMulitCol(CString strSql,CStringArray& Result);
   
    //打开表
    BOOL OpenTable(CString strTable);
   
    //打开表
    BOOL OpenTable(CString strTable,CStringArray& Result);
   
    //进行其它的更新操作
    BOOL Execute(CString strSql);
public:
    BOOL ExecuteTrans(CStringArray& aSql);   
   
    //关闭结果集合
    void CloseRecordset();
   
    //得到操作结果的列数
    long GetResultCol();
   
    //得到操作结果的条数
    long GetResultRow();
   
    //得到操作结果
    _RecordsetPtr GetResult();
private:
   
    //数据库操作返回的结果条数
    long m_nResultRow;
   
    //返回的_RecordsetPtr中列数
    long m_nResultCol;
   
    //连接指针
    _ConnectionPtr m_pConnection;
   
    //命令执行指针
    _CommandPtr m_pCommand;
   
    //结果集指针
    _RecordsetPtr m_pRecordset;
};

/**************************************************************
CPFile.cpp
**************************************************************/

//////////////////////////////////////////////////////////////////////
// 构造函数
//////////////////////////////////////////////////////////////////////
//默认的构造函数
CPData::CPData()
{
    //初始化
    m_nResultRow = 0;
    m_nResultCol=0;
    m_pConnection = NULL;
    //创建对象
    m_pRecordset.CreateInstance(_uuidof(Recordset));
    m_pCommand.CreateInstance(_uuidof(Command));
}

//传入参数的构造函数
CPData::CPData(_ConnectionPtr pConnection)
{
    m_pConnection = pConnection;
    m_nResultRow = 0;
    m_nResultCol=0;
    //创建对象
    m_pRecordset.CreateInstance(_uuidof(Recordset));
    m_pCommand.CreateInstance(_uuidof(Command));
   
}
//////////////////////////////////////////////////////////////////////
// 析构函数
//////////////////////////////////////////////////////////////////////
CPData::~CPData()
{
    if(m_pRecordset->State!=adStateClosed)
        m_pRecordset->Close();
    m_pRecordset = NULL;

    if(m_pCommand->State!=adStateClosed)
        m_pCommand->Release();
    m_pCommand = NULL;

    if(m_pConnection->State!=adStateClosed)
        m_pConnection->Close();
    m_pConnection = NULL;
}

/////////////////////////////////////////////////////////////////////
///简单操作函数
////////////////////////////////////////////////////////////////////

//得到操作结果的行数
long CPData::GetResultRow()
{
    return this->m_nResultRow;
}

//得到操作结果的列数
long CPData::GetResultCol()
{
    return this->m_nResultCol;
}

//得到操作结果
_RecordsetPtr CPData::GetResult()
{
    return this->m_pRecordset;
}

///////////////////////////////////////////////////////////////////////
///连接操作
///////////////////////////////////////////////////////////////////////

//连接到数据库
//1.连接字符串可以自己构造,也可以从文件中读出
BOOL CPData::Connect(CString strUser,CString strPassword,CString strFileName,int nOptions,CString strConStr)
{
    try{
        m_pConnection.CreateInstance(__uuidof(Connection));
        HRESULT hr;
        //如果用文件方式配置数据源,进行配置
        if(strFileName.Compare("")!=0&&CPFile::IsFileExist(strFileName))
        {
            CString con = "File Name="+strFileName;
            m_pConnection->ConnectionString =(_bstr_t)con;
            hr=m_pConnection->Open("","","",nOptions);   
        }
        else
        {
            //自己配置连接字符串
            m_pConnection->ConnectionString = (_bstr_t)strConStr;
            hr=m_pConnection->Open("",_bstr_t(strUser),_bstr_t(strPassword),nOptions); 
        }
        //进行连接
        //连接失败
        if(FAILED(hr))
        {  
            AfxMessageBox("连接失败!");
            return FALSE;
        }
    }
    catch(_com_error&e)
    {
        AfxMessageBox(e.Description()+"B");
        return FALSE;
    }
    return TRUE;
}

//断开连接
void CPData::DisConnect()
{
    if(m_pConnection->State!=adStateClosed)
        m_pConnection->Close();
}

///////////////////////////////////////////////////////////////////////
///更新操作
///////////////////////////////////////////////////////////////////////
BOOL CPData::Execute(CString strSql)
{
    try
    {
        _variant_t vNULL;
        vNULL.vt = VT_ERROR;
       
        ///定义为无参数
        vNULL.scode = DISP_E_PARAMNOTFOUND;
       
        ///非常关键的一句,将建立的连接赋值给它
        m_pCommand->ActiveConnection = m_pConnection;
       
        ///命令字串
        m_pCommand->CommandText = (_bstr_t)strSql;
       
        ///执行命令,取得记录集
        m_pRecordset = m_pCommand->Execute(&vNULL,&vNULL,adCmdText);
       
        //确实,vNULL中的intVal是执行操作所影响的行数
        m_nResultRow = 0;
        m_nResultRow = vNULL.intVal; 
    }
    catch(_com_error&e)
    {
        m_nResultRow = 0; 
        return FALSE;
    }
    return TRUE;
}

///////////////////////////////////////////////////////////////////////
///查询操作
///////////////////////////////////////////////////////////////////////
BOOL CPData::Select(CString strSql)
{
    try
    {
        m_nResultCol=0;
        m_nResultRow=0; 
        m_pRecordset->CursorLocation=adUseClient;    //设置游标位置,设置为客户端形式,否则GetRecordCount()返回值不对
        m_pRecordset->Open(_variant_t(strSql),_variant_t((IDispatch *)m_pConnection,true),adOpenDynamic,adLockOptimistic,adCmdText);
        m_nResultCol = m_pRecordset->Fields->GetCount();//得到查询结果的列数
        m_nResultRow = m_pRecordset->GetRecordCount();  //得到查询结果的行数
    }
    catch(_com_error&e)
    { 
        AfxMessageBox(e.Description()+"D");
        return FALSE;
    }
    return TRUE;
}

//查询语句,负责对仅仅查询一个字段的情况进行处理
//结果存放在CStringArray类型的变量pResult中
BOOL CPData::Select(CString strSql,CStringArray& Result)
{
    if(Select(strSql)!=0)
    {
        Result.RemoveAll();
        for(int i=0;i<m_nResultRow;i++)
        {
            _variant_t value;
            value=m_pRecordset->Fields->Item[(long)0]->Value;  
            if(value.vt==3||value.vt==14)
            {
                CString strTrans;
                strTrans.Format("%ld",value.intVal);
                Result.Add(strTrans);
            }
            else
                Result.Add(value.bstrVal);//
            m_pRecordset->MoveNext();
        }
        m_pRecordset->Close();
        return TRUE;
    }
    else
    {
        m_pRecordset->Close();
        return FALSE;
    }
}

BOOL CPData::SelectMulitCol(CString strSql,CStringArray& Result)
{
    if(Select(strSql)!=0)
    {
        Result.RemoveAll();
        _variant_t value;
        for(int i=0;i<m_nResultRow;i++)
        {  
            for(int j=0;j<m_nResultCol;j++)
            {
                value=m_pRecordset->Fields->Item[(long)(/*i*m_nResultCol+*/j)]->Value;
                if(value.vt==3||value.vt==14)
                {
                    CString strTrans;
                    strTrans.Format("%ld",value.intVal);
                    Result.Add(strTrans);
                }
                else
                    if(value.vt==7)
                    {
                        COleDateTime time = value.date;
                        CString strTemp;
                        strTemp.Format("%d-%d-%d %s",time.GetYear(),time.GetMonth(),time.GetDay(),time.Format("%H:%M:%S"));
                        Result.Add(strTemp);
                    }
                    else
                        Result.Add(value.bstrVal);//
            }
            m_pRecordset->MoveNext();
        }
        m_pRecordset->Close();
        return TRUE;
    }
    else
    {
        m_pRecordset->Close();
        return FALSE;
    }
}

//打开整张表
BOOL CPData::OpenTable(CString strTable)
{
    try
    {
        m_nResultCol=0;
        m_nResultRow=0; 
        m_pRecordset->CursorLocation=adUseClient;    //设置游标位置,设置为客户端形式,否则GetRecordCount()返回值不对
        m_pRecordset->Open(_variant_t(strTable),_variant_t((IDispatch *)m_pConnection,true),adOpenDynamic,adLockOptimistic,adCmdTable);
        m_nResultCol = m_pRecordset->Fields->GetCount();//得到查询结果的列数
        m_nResultRow = m_pRecordset->GetRecordCount();  //得到查询结果的行数
    }
    catch(_com_error&e)
    { 
        AfxMessageBox(e.Description()+"E");
        return FALSE;
    }
    return TRUE;
}

BOOL CPData::OpenTable(CString strTable,CStringArray& Result)
{
    if(OpenTable(strTable)!=0)
    {
        Result.RemoveAll();
        _variant_t value;
        for(int i=0;i<m_nResultRow;i++)
        {  
            for(int j=0;j<m_nResultCol;j++)
            {
                value=m_pRecordset->Fields->Item[(long)(/*i*m_nResultCol+*/j)]->Value;
                if(value.vt==3||value.vt==14)
                {
                    CString strTrans;
                    strTrans.Format("%ld",value.intVal);
                    Result.Add(strTrans);
                }
                else
                    if(value.vt==7)
                    {
                        COleDateTime time = value.date;
                        CString strTemp;
                        strTemp.Format("%d-%d-%d %s",time.GetYear(),time.GetMonth(),time.GetDay(),time.Format("%H:%M:%S"));
                        Result.Add(strTemp);
                    }
                    else
                        Result.Add(value.bstrVal);//
            }
            m_pRecordset->MoveNext();
        }
        m_pRecordset->Close();
        return TRUE;
    }
    else
    {
        return FALSE;
    }
}

/////////////////////////////////////////////////////////////////////////////
///关闭结果集
/////////////////////////////////////////////////////////////////////////////
void CPData::CloseRecordset()
{
    if(m_pRecordset->State != adStateClosed)
        m_pRecordset->Close();
}
BOOL CPData::ExecuteTrans(CStringArray& aSql)
{
    try{
        int nNum = aSql.GetSize();
        m_pConnection->BeginTrans();
        for(int i=0;i<nNum;i++)
        {
            CString strSql = aSql.GetAt(i); 
            m_pConnection->Execute((_bstr_t)aSql.GetAt(i),NULL,adCmdText);
        }
        m_pConnection->CommitTrans();
        return TRUE;
    }
    catch(_com_error& e)
    {
        m_pConnection->RollbackTrans(); 
        AfxMessageBox(e.Description()+"F");
        return FALSE;
    }
}
分享到:
评论

相关推荐

    VC MFC_ADO 数据库操作

    例如,“第21章 ADO数据库编程”很可能包含了一系列的实例,讲解如何使用MFC ADO进行数据库操作,包括连接数据库、执行查询、处理结果集等步骤。 总之,MFC ADO为VC程序员提供了一种高效、灵活的数据库访问方式,...

    VC Ado数据库操作类(ado2)

    `VC ADO数据库操作类(ado2)`是一个专门为VC++设计的类库,简化了数据库操作,使开发者能够更加高效地处理数据库任务。 `ado2.cpp`和`ado2.h`是这个类库的核心文件,其中`ado2.cpp`包含了类库的实现细节,而`ado2.h`...

    VC与ADO数据库操作1.doc

    【VC与ADO数据库操作】 在VC++开发数据库应用程序时,ADO(ActiveX Data Objects)是一种常用的接口,它基于OLE DB,提供了一种高效且易于使用的数据访问方式。ADO简化了数据库交互,使得开发者无需深入理解底层的...

    VC下ADO访问数据库的类

    这个"VC下ADO访问数据库的类"源码是一个实用的工具,它封装了ADO的基本操作,方便开发者在VC项目中快速实现数据库的读写功能。 首先,我们需要了解ADO的核心组件。主要包括: 1. **Connection对象**:这是ADO的...

    VC访问数据库的ADO封装类

    ADO封装类是将ADO接口进行包装,以便于开发者更简单、直观地操作数据库。这篇文档将深入探讨如何在VC中使用ADO封装类来实现数据库的访问。 首先,ADO是.NET Framework的一部分,但在VC++环境下,我们通常使用的是...

    使用VC及ADO进行数据库编程

    在实现过程中,作者创建了一个名为`cRecorder`的自定义数据库类,该类封装了ADO的基本接口,包括建立数据库连接、执行SQL语句以及对记录的增删查改操作。`cRecorder`类的成员变量和函数包括用于存储和操作数据库信息...

    VC数据库操作类 ADO操作类

    总结来说,"VC数据库操作类 ADO操作类"是一个强大的数据库操作工具,它通过封装ADO接口,为VC++开发者提供了简单易用的数据库操作API,使得数据库操作更加便捷高效。同时,考虑到其对OFFICE文档的支持,它在数据导入...

    VC++ 封装的Ado操作类

    VC++ 封装的Ado操作类,可以对数据库进行简单的增删改查,而不用直接调用ADO的是三个接口,操作简单

    VC中操作ADO数据库资料.rar_VC ADO sql_sqlserver_vc ado sql server_vc sql

    VC编程封装ADO类 VC中利用ADO共同实现数据库的操作 在VC中使用ADO开发数据库应用程序 用C++访问SQLServer2000的实例

    ADO封装类文件 数据库访问

    在这个场景中,"ADO封装类文件 数据库访问"指的是在VC6.0环境下,已经编写完成的用于简化ADO操作的C++类库,包括两个文件:ADOConn.h和ADOConn.cpp。 **ADOConn.h** 文件通常会定义一个名为ADOConn的类,这个类是对...

    ADO封装类 VC操作数据库容易方便

    ADO封装类使得开发者能够更简单、方便地执行SQL语句并操作数据库,无需深入了解底层的数据库通信细节。本文将深入探讨如何使用ADO在VC++中进行数据库操作,并基于提供的文件`SqlServer.cpp`、`SqlServer.h`以及可能...

    ado C++数据库类

    在这个"ado C++数据库类"中,我们可能找到了一个封装了ADO接口的C++类库,使得在Visual C++(VC)环境中进行数据库操作更加简便。 1. **ADO基础**:ADO是OLE DB的一部分,它提供了一种高层级的、面向对象的方式来...

    VC使用ADO简单示例

    2. **VC编程封装ADO类**:在VC项目中,通常会创建类来封装ADO对象,这样可以提高代码的可读性和可维护性。例如,可以创建一个CDatabase类,封装Connection对象,以及CRowset类,封装Recordset对象。这些类可以包含...

    VC里ADO数据库的连接再述

    2. **使用ATL ADO封装**:Microsoft还提供了ATL(Active Template Library)对ADO的封装,如`CADORecordset`和`CADODatabase`类。这使得操作数据库更加方便,减少了直接使用ADO时的代码量。例如: ```cpp ...

    经典数据库封装类 ado2

    标题中的"经典数据库封装类 ado2"指的是一个由Carlos Antollini开发的C++库,它主要用于简化在VC(Visual C++)环境下对数据库的操作。这个库是对ADO(ActiveX Data Objects)的一种封装,ADO是Microsoft提供的用于...

    C++封装ADO数据库连接,附上DLL源码和测试程序

    因工作需要,一些项目中频繁的用到ADO连接数据库,每次都要写一些初始化过程,或者copy过来大篇代码。 “一份好的代码,一用好多年,封装成动态库,一直带身边”,为了提高工作效率或者说为了偷懒,就封装出这么一...

    我用vc写的ADO访问数据库的类

    这个类可能封装了建立数据库连接、执行SQL查询、处理结果集以及事务管理等一系列操作,使得开发者在实际项目中可以更便捷地进行数据库操作,而无需直接与复杂的ADO API打交道。 关于ADO数据库访问的知识点包括: 1...

    vs2008 可用的 ado 封装类

    标题中的“vs2008 可用的 ado 封装类”指的是在Visual Studio 2008(VS2008)环境下,利用ADO(ActiveX Data Objects)技术进行数据库访问的一种封装方法。ADO是微软提供的一个数据访问接口,它允许开发者通过OLE DB...

Global site tag (gtag.js) - Google Analytics