工大后院

 找回密码
 加入后院

扫一扫,访问微社区

QQ登录

只需一步,快速开始

搜索
查看: 4232|回复: 10

VC++用那种技术连接数据库比较简单?

[复制链接]
发表于 2008-6-16 20:38 | 显示全部楼层 |阅读模式
1.ODBC API;
2.MFC ODBC类;
3.MFC DAO类;(数据访问对象)
4.MFC的OLE/DB;
5.ActiveX数据对象(ADO)。
以上那种技术比较适合初学者?我想用VC++和SQL Server进行连接。
发表于 2008-6-16 21:03 | 显示全部楼层
全部都学,然后再做比较吧...
回复

使用道具 举报

发表于 2008-6-16 21:20 | 显示全部楼层

ADO

我用的是ADO,下面的自己写的一个数据库操作类
//AdoConnect.h
class CAdoConnect  //创建访问数据库的类,基于ADO访问技术
{
public:
_RecordsetPtr m_pRecordset;   //定义一个记录集对象
_ConnectionPtr m_pConnection;  //定义一个连接对象
void ExitConnect();           //关闭连接
BOOL ExecuteSQL(_bstr_t bstrSQL);//执行参数指定的SQL语句
_RecordsetPtr& GetRecordSet(_bstr_t bstrSQL);//执行参数指定的SQL语句,并返回一个记录集的指针
BOOL OnInitDBConnect();     //初始化数据库连接
CAdoConnect();   //构造函数
virtual ~CAdoConnect();  //析构函数
};

//AdoConnect.cpp
CAdoConnect::CAdoConnect()
{
}
CAdoConnect::~CAdoConnect()
{
}
BOOL CAdoConnect::OnInitDBConnect()   //该方法用于连接到数据库,成功连接时返回true,失败时返回false
{
    ::CoInitialize(NULL);        //初始化OLE/COM环境
HRESULT hr;
try
{
  hr = m_pConnection.CreateInstance("ADODB.Connection");      //创建Connection对象
  if(SUCCEEDED(hr))
  {
   _bstr_t strConnect;
   strConnect="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Hotel.mdb;Persist Security Info=False;Jet OLEDB:Database Password=1234";
   m_pConnection->ConnectionTimeout =30;                      //设置超时时间为5秒
   hr = m_pConnection->Open(strConnect,"","",adModeUnknown);
  }
}
catch(_com_error e)         //捕捉异常
{
  CString errormessage;
  errormessage.Format("连接数据库失败!\r\n错误信息:%s",e.ErrorMessage());
  AfxMessageBox(errormessage);
  return false;
}
return true;
}
_RecordsetPtr& CAdoConnect::GetRecordSet(_bstr_t bstrSQL)//从数据库中获得记录
{
try
{
  if(m_pConnection==NULL)      //连接数据库,如果Connection对象为空,则重新连接数据库
   OnInitDBConnect();
  m_pRecordset.CreateInstance("ADODB.Recordset");   
  m_pRecordset->Open(bstrSQL,_variant_t((IDispatch *)m_pConnection,true),adOpenDynamic,adLockOptimistic,adCmdText);      //取得表中的记录
}
catch(_com_error e)       //捕捉异常
{
  CString errormessage;
  errormessage.Format("获取数据库记录失败!\r\n错误信息:%s",e.ErrorMessage());
  AfxMessageBox(errormessage);   
}
return m_pRecordset;       //返回结果集
}
BOOL CAdoConnect::ExecuteSQL(_bstr_t bstrSQL)//执行参数bstrSQL所指定的SQL语句
{
_variant_t RecordsAffected;
try
{
  if(m_pConnection==NULL)
   OnInitDBConnect();
  m_pConnection->Execute(bstrSQL,&RecordsAffected,adCmdText);
  return true;
}
catch(_com_error e)
{
  CString errormessage;
  errormessage.Format("执行语句失败!\r\n错误信息:%s",e.ErrorMessage());
  AfxMessageBox(errormessage);
  return false;
}
}
void CAdoConnect::ExitConnect()//断开与数据库的连接
{
   if(m_pRecordset!=NULL)      //关闭记录集
    m_pRecordset->Close();
   if(m_pConnection->State)    //关闭连接
       m_pConnection->Close();
   ::CoUninitialize();     //释放环境
}

评分

1

查看全部评分

回复

使用道具 举报

 楼主| 发表于 2008-6-16 23:14 | 显示全部楼层
原帖由 Teson 于 2008-6-16 21:20 发表
我用的是ADO,下面的自己写的一个数据库操作类
//AdoConnect.h
class CAdoConnect  //创建访问数据库的类,基于ADO访问技术
{
public:
_RecordsetPtr m_pRecordset;   //定义一个记录集对象
_ConnectionPtr  ...

可以详细的解释一下吗?新手看不懂 ...先谢了~
回复

使用道具 举报

发表于 2008-6-18 00:05 | 显示全部楼层
5.ActiveX数据对象(ADO)
回复

使用道具 举报

发表于 2008-6-18 10:45 | 显示全部楼层
mfc的odbc个人觉得简单一些

我记得当时我做数据库课程设计时,在网上随便找了几篇文章看看就开始写了

这次毕业设计我也用的是这个
回复

使用道具 举报

发表于 2008-6-18 20:24 | 显示全部楼层

回复 板凳 Teson 的帖子

先看找书看下ADO几个重要的对象,再跟着程序的注释不难理解的。。。。
回复

使用道具 举报

发表于 2008-6-19 17:22 | 显示全部楼层
ADO技术,如果你有一点C++基础。
封装后就可以让你为所欲为了。
回复

使用道具 举报

发表于 2008-6-19 23:01 | 显示全部楼层
原帖由 hongbobo 于 2008-6-19 17:22 发表
ADO技术,如果你有一点C++基础。
封装后就可以让你为所欲为了。


C++基础指的是什么呢,纯C基础算不算?
ADO技术怎么“封装”?“封装”之后怎么“为所欲为”?
回复

使用道具 举报

发表于 2008-6-29 18:45 | 显示全部楼层
连接数据库也可以算是基本技能要求的一种了吧
建议还是要全面了解下每种连接方式之间的关系,优缺点及适用范围
回复

使用道具 举报

发表于 2008-6-29 18:47 | 显示全部楼层
至于封装,可以先自己写些代码,当你发现有某段代码要重复了双重复时,你就应该想到把它“封装”起来了,当然,最快最懒的方法是直接用现在的代码。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 加入后院

本版积分规则

QQ|Archiver|手机版|小黑屋|广告业务Q|工大后院 ( 粤ICP备10013660号 )

GMT+8, 2025-5-14 07:00

Powered by Discuz! X3.5

Copyright © 2001-2024 Tencent Cloud.

快速回复 返回顶部 返回列表