找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 619|回复: 6

[求助] ObjectARX连接Access数据库中遇到的AutoCAD软件异常问题

[复制链接]
发表于 2018-5-17 20:05:24 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
刚开始接触ObjectARX二次开发,最近进展到连接数据库部分,发现在VS中程序代码编译无误通过,也能生成可以运行的arx文件,但是在AutoCAD2018中运行arx文件时,运行到连接数据库部分时就出现了如下的问题,AutoCAD软件退出,有没有大神指点一下,代码在生成基于对话框的MFC软件能正常连接数据库并运行。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
 楼主| 发表于 2018-5-17 20:09:07 | 显示全部楼层
C:\Users\ThinkPad\Desktop\错误.PNG
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-17 20:12:31 | 显示全部楼层
  1. void Test() {
  2.         _ConnectionPtr m_pConnection;
  3.         _RecordsetPtr m_pRecordset;
  4.         AfxOleInit();
  5.         m_pConnection.CreateInstance(__uuidof(Connection));

  6.         try
  7.         {
  8.                 // 打开本地Access库Demo.mdb
  9.                 m_pConnection->Open("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=txsj.accdb", "", "", adModeUnknown);
  10.                 //注意这里一个字都不可以错。。。否则。程序会发生错误
  11.         }
  12.         catch (_com_error * e)
  13.         {
  14.                 CString errormessage;
  15.                 errormessage.Format(_T("错误信息:%s"), e->ErrorMessage());
  16.                 AfxMessageBox(errormessage);
  17.                 AfxMessageBox(_T("数据库连接失败,确认数据库txsj.mdb是否在当前路径下!"));

  18.                 return ;
  19.         }
  20.         m_pRecordset.CreateInstance(__uuidof(Recordset));


  21.         // 在ADO操作中建议语句中要常用try...catch()来捕获错误信息,
  22.         // 因为它有时会经常出现一些想不到的错误。
  23.         try
  24.         {
  25.                 m_pRecordset->Open("SELECT * FROM 铁心数据",                 // 查询铁心数据表中所有字段
  26.                         m_pConnection.GetInterfacePtr(),                        // 获取库连接的IDispatch指针
  27.                         adOpenDynamic,
  28.                         adLockOptimistic,
  29.                         adCmdText);
  30.         }
  31.         catch (_com_error * e)
  32.         {
  33.                 CString errormessage;
  34.                 errormessage.Format(_T("错误信息:%s"), e->ErrorMessage());
  35.                 AfxMessageBox(errormessage);
  36.         }
  37.         AfxMessageBox(_T("连接数据库成功"));
  38.         m_pRecordset->Close();
  39.         m_pConnection->Close();


  40. }
复制代码
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-17 20:14:33 | 显示全部楼层
测试连接数据库是否成功的代码(一样,一运行就出错),运行后显示内存出错
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-17 20:16:50 | 显示全部楼层
AutoCAD显示
错误.PNG
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-17 20:18:20 | 显示全部楼层
AutoCAD显示
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 5060个

财富等级: 富甲天下

发表于 2018-5-18 13:03:01 来自手机 | 显示全部楼层
哪一句出错了,删掉再测试一下
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-4-26 09:32 , Processed in 0.385154 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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