mwq0611 2018-08-21 23:19 采纳率: 100%
浏览 844
已采纳

在MFC中用ADO连接excel时找不到数据表

无论是用ADO的OpenSchema( adSchemaTables ),还是用 ADOX 的 _CatalogPtr 找系统表,都找不到数据表,而文件里面又确实有一个表,这是什么原因?
附程序代码:

ADODB::_ConnectionPtr m_pConnection;
ADODB::_RecordsetPtr m_pRecordset;
::CoInitialize( NULL );
m_pConnection.CreateInstance( __uuidof( ADODB::Connection ) );
m_pRecordset.CreateInstance( __uuidof( ADODB::Recordset ) );

CString csConnect;
csConnect.Format("Provider=Microsoft.ACE.OLEDB.12.0;"
            "Data Source='txlx.xls'; Extended Properties='Excel 8.0;HDR=YES;IMEX=0'" );

_bstr_t strConnect;
strConnect = csConnect;

try{
m_pConnection ->Open( strConnect, "", "", ADODB::adConnectUnspecified );
}
catch( _com_error &e )
{
    CString szError;
    szError.Format( "数据库连接失败!\n%s\n%s", e.ErrorMessage(), (char*)(e.Description()) );
    MessageBox( szError );
}

_CatalogPtr m_pCatalog = NULL;
_TablePtr m_pTable = NULL;
m_pCatalog.CreateInstance( __uuidof( Catalog ));

try{
m_pCatalog ->PutActiveConnection( _variant_t((IDispatch*)m_pConnection));
}
catch( _com_error &e )
{
    CString szError;
    szError.Format( "数据目录关联失败!\n%s\n%s", e.ErrorMessage(), (char*)(e.Description()) );
    MessageBox( szError );
}

_variant_t vIndex = (short)0;

try{
    m_pTable = m_pCatalog ->Tables ->GetItem( vIndex );
    AfxMessageBox( m_pTable ->Name );
}
catch( _com_error &e )
{
    CString szError;
    szError.Format( "数据表获取失败!\n%s\n%s", e.ErrorMessage(), (char*)(e.Description()) );
    MessageBox( szError );
}


if( m_pRecordset != NULL && m_pRecordset ->State == ADODB::adStateOpen )
{
    m_pRecordset ->Close();
}

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

m_pConnection.Release();
m_pRecordset.Release();
::CoUninitialize(); 

错误提示:数据表获取失败!
                在对应所需名称或序数的集合中,未找到项目。

展开全部

  • 写回答

1条回答 默认 最新

  • threenewbee 2018-08-22 02:49
    关注

    csConnect.Format("Provider=Microsoft.ACE.OLEDB.12.0;"
    "Data Source='txlx.xls'; Extended Properties='Excel 8.0;HDR=YES;IMEX=0'" );
    你这个代码按理说根本都不能编译啊,两个字符串,中间没有任何符号。
    你贴的是原始代码么?
    另外datasource写完整的路径和文件名,以及,你确认ace12.0是否安装了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 代写uni代码,app唤醒
  • ¥15 全志t113i启动qt应用程序提示internal error
  • ¥15 ensp可以看看嘛.
  • ¥80 51单片机C语言代码解决单片机为AT89C52是清翔单片机
  • ¥60 优博讯DT50高通安卓11系统刷完机自动进去fastboot模式
  • ¥15 minist数字识别
  • ¥15 在安装gym库的pygame时遇到问题,不知道如何解决
  • ¥20 uniapp中的webview 使用的是本地的vue页面,在模拟器上显示无法打开
  • ¥15 网上下载的3DMAX模型,不显示贴图怎么办
  • ¥15 关于#stm32#的问题:寻找一块开发版,作为智能化割草机的控制模块和树莓派主板相连,要求:最低可控制 3 个电机(两个驱动电机,1 个割草电机),其次可以与树莓派主板相连电机照片如下:
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部