请问在VC++2010中如何连接用Access2010创建好的accdb数据库?

时间:2022-09-07 20:16:39
我模仿VC6的连接过程 连接我事先建好的数据库(我选的是连接ODBC),但是在向导的最后一步点完成的时候 VC++2010就直接崩溃了,我百度了一下,有人跟我碰到同样的问题,但是没人给出解决方案,有大神赐教么?

9 个解决方案

#1


头文件里开始处:
#import   "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename   ("EOF",   "adoEOF")
头文件里类里:
_ConnectionPtr m_pConnection;
_RecordsetPtr m_pRecordset;
_CommandPtr m_pCommand;

CPP文件里:
BOOL CDatabaseDll::OpenDatabaseFun(_ConnectionPtr pConnection,_RecordsetPtr pRecordset,_CommandPtr pCommand)
{
BOOL Result=TRUE;
HRESULT   hr;
try   
{   
hr = pConnection.CreateInstance("ADODB.Connection");///创建Connection对象
if(SUCCEEDED(hr))   
{   
pConnection->ConnectionTimeout   =   10;   
//  hr   =   m_pConnection->Open(   "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\NW.mdb","", "", adModeUnknown);//这是OFFICE2003以下的
hr = pConnection->Open("Provider=Microsoft.Ace.Oledb.12.0;Data Source=D:\\bagayalu.accdb;Jet OLEDB:Database Password=123456","", "", adModeUnknown);//这是OFFICE2007以上的,包括OFFICE2010,这个连接字符串就是在OFFICE2010下用的,没问题
  
//m_pConnection->PutDefaultDatabase   ((_bstr_t)"DB");//设置默认数据库   
    
pCommand.CreateInstance(__uuidof(Command));
pCommand->CommandTimeout = 5;
pCommand->ActiveConnection = pConnection;
}
}
catch(_com_error   e)///捕捉异常
{
CString   errormessage;
errormessage.Format("连接数据库失败!/r/n错误信息:%s",e.ErrorMessage());
AfxMessageBox(errormessage);///显示错误信息
Result=FALSE;
return Result;

_variant_t   var;
float v1,v2,v3,v4;
CString Remark;
pRecordset.CreateInstance(__uuidof(Recordset));
try
{
pRecordset->Open("SELECT * FROM 表1",//   查询DemoTable表中所有字段   
pConnection.GetInterfacePtr(),//   获取库接库的IDispatch指针   
adOpenDynamic,
adLockOptimistic,
adCmdText);

}
catch(_com_error   *e)
{
AfxMessageBox(e->ErrorMessage());
Result=FALSE;
return Result;
}
return Result;
}

#2


用ADO操作数据库吧,不要用ODBC,ODBC只是很多年前用的,现在应该算是淘汰了很少用了,多数是用ADO了.这是在打开记录集后进行查询显示数据:
while(!m_pRecordset->adoEOF)   
  {   
  var   =   m_pRecordset->GetCollect("v1");   
  if(var.vt   !=   VT_NULL)
  v1=var.fltVal;
//  strName   =   (LPCSTR)_bstr_t(var);   

  var   =   m_pRecordset->GetCollect("v2");   
  if(var.vt   !=   VT_NULL)   
  v2=var.fltVal;
  var   =   m_pRecordset->GetCollect("v3");   
  if(var.vt   !=   VT_NULL)   
  v3=var.fltVal;
  var   =   m_pRecordset->GetCollect("v4");   
  if(var.vt   !=   VT_NULL)   
  v4=var.fltVal;
  var   =   m_pRecordset->GetCollect("remark");   
  if(var.vt   !=   VT_NULL)
Remark   =   (LPCSTR)_bstr_t(var);
  m_pRecordset->MoveNext();   
  } 

#3


2010直接崩溃?
如果你是按着向导讲数据源添加进去的这可能是个bug

#4


确实是直接崩溃的。
引用 3 楼  的回复:
2010直接崩溃?
如果你是按着向导讲数据源添加进去的这可能是个bug

#5


兄弟,我的方法是用ACCESS2010建立了一个老版本的数据库,后缀是.mdb,至于如何创建的呢?
打开Microsoft Access 2010,文件->选项->常规->创建数据库下的:空白数据库的默认文件格式:选择Access2002-2003,然后确认,然后就可以创建.mdb后缀的数据库了
这样网上的一些老的方法就可以直接拿过来用了
希望给你帮助,我前几天刚弄的

#6


但是这样会有两个结果,一个后缀是accdb 一个mdb,

#7


使用ACCESS2010的人,机器上要安装ACE 引擎,Microsoft.ACE.OLEDB.12.0 安装文件:

http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=7554f536-8c28-4598-9b72-ef94e038c891

#8


Access2010的默认的编码方式是什么?

#9


,Microsoft.ACE.OLEDB.12.0  装了这个,换个机子就很难运行

#1


头文件里开始处:
#import   "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename   ("EOF",   "adoEOF")
头文件里类里:
_ConnectionPtr m_pConnection;
_RecordsetPtr m_pRecordset;
_CommandPtr m_pCommand;

CPP文件里:
BOOL CDatabaseDll::OpenDatabaseFun(_ConnectionPtr pConnection,_RecordsetPtr pRecordset,_CommandPtr pCommand)
{
BOOL Result=TRUE;
HRESULT   hr;
try   
{   
hr = pConnection.CreateInstance("ADODB.Connection");///创建Connection对象
if(SUCCEEDED(hr))   
{   
pConnection->ConnectionTimeout   =   10;   
//  hr   =   m_pConnection->Open(   "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\\NW.mdb","", "", adModeUnknown);//这是OFFICE2003以下的
hr = pConnection->Open("Provider=Microsoft.Ace.Oledb.12.0;Data Source=D:\\bagayalu.accdb;Jet OLEDB:Database Password=123456","", "", adModeUnknown);//这是OFFICE2007以上的,包括OFFICE2010,这个连接字符串就是在OFFICE2010下用的,没问题
  
//m_pConnection->PutDefaultDatabase   ((_bstr_t)"DB");//设置默认数据库   
    
pCommand.CreateInstance(__uuidof(Command));
pCommand->CommandTimeout = 5;
pCommand->ActiveConnection = pConnection;
}
}
catch(_com_error   e)///捕捉异常
{
CString   errormessage;
errormessage.Format("连接数据库失败!/r/n错误信息:%s",e.ErrorMessage());
AfxMessageBox(errormessage);///显示错误信息
Result=FALSE;
return Result;

_variant_t   var;
float v1,v2,v3,v4;
CString Remark;
pRecordset.CreateInstance(__uuidof(Recordset));
try
{
pRecordset->Open("SELECT * FROM 表1",//   查询DemoTable表中所有字段   
pConnection.GetInterfacePtr(),//   获取库接库的IDispatch指针   
adOpenDynamic,
adLockOptimistic,
adCmdText);

}
catch(_com_error   *e)
{
AfxMessageBox(e->ErrorMessage());
Result=FALSE;
return Result;
}
return Result;
}

#2


用ADO操作数据库吧,不要用ODBC,ODBC只是很多年前用的,现在应该算是淘汰了很少用了,多数是用ADO了.这是在打开记录集后进行查询显示数据:
while(!m_pRecordset->adoEOF)   
  {   
  var   =   m_pRecordset->GetCollect("v1");   
  if(var.vt   !=   VT_NULL)
  v1=var.fltVal;
//  strName   =   (LPCSTR)_bstr_t(var);   

  var   =   m_pRecordset->GetCollect("v2");   
  if(var.vt   !=   VT_NULL)   
  v2=var.fltVal;
  var   =   m_pRecordset->GetCollect("v3");   
  if(var.vt   !=   VT_NULL)   
  v3=var.fltVal;
  var   =   m_pRecordset->GetCollect("v4");   
  if(var.vt   !=   VT_NULL)   
  v4=var.fltVal;
  var   =   m_pRecordset->GetCollect("remark");   
  if(var.vt   !=   VT_NULL)
Remark   =   (LPCSTR)_bstr_t(var);
  m_pRecordset->MoveNext();   
  } 

#3


2010直接崩溃?
如果你是按着向导讲数据源添加进去的这可能是个bug

#4


确实是直接崩溃的。
引用 3 楼  的回复:
2010直接崩溃?
如果你是按着向导讲数据源添加进去的这可能是个bug

#5


兄弟,我的方法是用ACCESS2010建立了一个老版本的数据库,后缀是.mdb,至于如何创建的呢?
打开Microsoft Access 2010,文件->选项->常规->创建数据库下的:空白数据库的默认文件格式:选择Access2002-2003,然后确认,然后就可以创建.mdb后缀的数据库了
这样网上的一些老的方法就可以直接拿过来用了
希望给你帮助,我前几天刚弄的

#6


但是这样会有两个结果,一个后缀是accdb 一个mdb,

#7


使用ACCESS2010的人,机器上要安装ACE 引擎,Microsoft.ACE.OLEDB.12.0 安装文件:

http://www.microsoft.com/downloads/details.aspx?displaylang=zh-cn&FamilyID=7554f536-8c28-4598-9b72-ef94e038c891

#8


Access2010的默认的编码方式是什么?

#9


,Microsoft.ACE.OLEDB.12.0  装了这个,换个机子就很难运行