在VC++.NET中使用ADO访问数据库

原创 2005年05月31日 02:45:00
在VC++.NET中使用ADO访问数据库

在VC++.NET中使用MFC中的CDatabase类和CRecordset类访问和操纵数据库是一件多么不优雅的

事情,所以下面提供了在VC++.NET中使用ADO访问和操纵数据库的一种解决方案。
步骤如下:
1,用#import指令引入ADO类型库,即导入msado15.dll
   
   非常简单,只要在stdafx.h文件中加入如下语句:

  #import "c:/program files/common files/system/ado/msado15.dll" no_namespace

rename("EOF","adoEOF")(注:该代码必须在同一行)

2,COM库的初始化

   使用AfxOleInit()来初始化COM库,通常在CWinApp::InitInstance()的重载函数中完成,请

看如下代码:
       
    if(!AfxOleInit())//这就是初始化COM库
    {
        AfxMessageBox("OLE初始化出错!");
        return FALSE;
    }

3,创建一个数据源,例如创建一个SQL Server2000的数据源。至于怎么创建和配置那就是小菜一碟了
读者认为是不是:)
4,接下来,便可以像平常使用ADO时编写访问数据库的代码了,我把所有的操作都放在按钮
   buton1的响应函数里,具体如下所示:
void CadoDlg::OnBnClickedButton1()
{
    CString strName, strSex, strAddress;
    
    _ConnectionPtr m_pConnection;
        _RecordsetPtr m_pRecordset

    m_pConnection.CreateInstance(_uuidof(Connection));
    m_pRecordset.CreateInstance(_uuidof(Recordset));
    m_pConnection->Open("DSN=DAXUE;uid=sa;pwd=123456;","","",0);//连接数据库
        
    CString strSql="select * from student";
        BSTR bstrSQL = strSql.AllocSysString();   
    m_pRecordset->Open(bstrSQL,
               (IDispatch*)m_pConnection,
                adOpenDynamic,adLockOptimistic,adCmdText);

    _variant_t  name , sex,address;
    try
    {
        m_pRecordset->MoveFirst();

        name = m_pRecordset->GetCollect("name");
        sex =  m_pRecordset->GetCollect("sex");
        address = m_pRecordset->GetCollect("address");

        if(name.vt != VT_NULL) strName = (char*)_bstr_t(name);
        if(sex.vt != VT_NULL) strSex = (char*)_bstr_t(sex);
        if(address.vt != VT_NULL) strAddress = (char*)_bstr_t(address);
    
    }
    catch(_com_error * e)
    {
        AfxMessageBox(e->ErrorMessage());

    }


    m_List.InsertColumn(0,"用户名");
    m_List.InsertColumn(1, "性别");
    m_List.InsertColumn(2, "地址");
    
    m_List.InsertItem( 0, strName);
    m_List.SetItemText( 0, 1, strSex);
    m_List.SetItemText( 0, 2, strAddress);


    m_pRecordset->Close(); //最后,记得释放已申请的资源。
    m_pConnection->Close();
    m_pRecordset = NULL;
    m_pConnection = NULL;
}
    
    最后总结一下,上面的操作中最容易出错的是配置数据源部分
即m_pConnection->Open("DSN=DAXUE;uid=sa;pwd=123456;","","",0);,读者自己好好
研究一下吧。
   不多说了,都2:33am了,要睡觉了,明天还要上可恶的《微机原理与接口技术》,
唉,痛苦啊!!!!

VC++下使用ADO访问Access数据库完整篇

这次先整理一下ADO的全套流程方便有类似需求的网友参考。实际上,根据天缘的经验,接口类编程只需要遵守人家的约定就可以了,很多做软件的网友也都是忙的很,没有时间一一深究。 1、在StdAfx.h中...
  • aasmfox
  • aasmfox
  • 2013年12月31日 15:09
  • 943

MS2010 VC++使用ADO访问数据库

下文介绍了使用MS2010开发坏境中的VC++和Microsoft.Jet.OLEDB.4.0数据库引擎操作ACCESS的通用类 1.头文件OperatorADO.h #pragma once #...

VC++6.0下使用ADO技术访问SQL 数据库

VC++6.0下使用ADO技术访问SQL 数据库 ******************************************************************...
  • lasolmi
  • lasolmi
  • 2014年11月17日 21:35
  • 546

VC++下使用ADO访问Access数据库完整篇

1、在StdAfx.h中引入ADO类支持 方法是在StdAfx.h中增加下面两句话: #include //如果需要则添加本句 #import "c:\program files\common ...
  • chw1989
  • chw1989
  • 2012年03月18日 11:46
  • 775

VC++中使用ADO访问SQL Server数据库与Access数据库的不同之处总结

最近调试一个VC++ Access数据库迁移到SQL Server平台的项目,遇到了一些问题,经过几天努力,通过论坛发帖子和资料查找,最后终于找到了问题所在,并顺利解决了问题,下面是一些总结,希望对碰...
  • zxhx
  • zxhx
  • 2011年03月04日 22:47
  • 2161

VC++使用ADO在数据库中访问记录

  • 2012年04月12日 22:08
  • 36KB
  • 下载

为了更方便使用ADO.NET访问数据库

使用ADO.NET访问数据库是目前较通用的手段,但使用过程中的感觉却差强人意,比如:频繁地处理DataSet, DataTable, DataAdapter 等对象。这次项目的时候,我把它再次封装了一...
  • qjpcpu
  • qjpcpu
  • 2012年03月25日 19:05
  • 638
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在VC++.NET中使用ADO访问数据库
举报原因:
原因补充:

(最多只允许输入30个字)