小小小小号丶 2018-10-11 07:55 采纳率: 0%
浏览 671

关于C++ MFC编程 _ConnectionPtr指针连接数据库ACCESS的问题

代码如图所示:
_ConnectionPtr m_pConn;
_variant_t RecordsAffected;
if (FAILED(m_pConn.CreateInstance("ADODB.Connection")))
{
AfxMessageBox(_T("Create Instance failed!"));
return;
}
else
{
m_pConn->Open("Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C://Users//liu//Desktop//database1.mdb", "", "", adModeUnknown);
//m_pConn->Open("Provider=Microsoft.ACE.OLEDB.12.0; Data Source=C://Users//liu//Desktop//数据库1.accdb;Persist Security Info=False;", "", "",adModeUnknown);
try
{
CString sql = _T("INSERT INTO user(username,password) VALUES(\"" + UserName + "\",\"" + Password + "\")");
AfxMessageBox(sql); //察看插入语句
m_pConn->Execute((_bstr_t)sql, &RecordsAffected, adCmdText);
}
catch (_com_error &e)
{
AfxMessageBox(_T("喵喵喵"));
m_pConn->Close();
}
m_pConn->Close();
}
return;
}
之前用JET的连接方式那个没什么问题,但是突然间就不能用了,换了ACE的连接方式还是不可以,程序中断后指向这个地方
inline HRESULT Connection15::Close ( ) {
HRESULT _hr = raw_Close();
if (FAILED(_hr)) _com_issue_errorex(_hr, this, __uuidof(this));
return _hr;
}
求大佬解答是什么原因

  • 写回答

1条回答 默认 最新

  • lshen01 2023-03-15 19:00
    关注

    参考GPT和自己的思路:

    根据你的代码,可能导致程序中断的原因有以下几点:

    1. 数据库文件路径不正确。确保数据库文件路径是正确的,并且文件存在。
    2. 数据库连接字符串有误。具体的连接字符串应该根据你所使用的数据库版本来确定,如果使用的是Access 2007及以上版本,则连接字符串应该为:

    "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C://Users//liu//Desktop//数据库1.accdb;Persist Security Info=False;"

    1. 数据库访问权限问题。如果你的数据库是受到保护的,则可能需要提供用户名和密码才能访问。在连接数据库时,应该提供正确的用户名和密码信息。

    除此之外,还可能存在其他问题导致程序中断。在调试程序的过程中,可以使用 Visual Studio 的调试工具来查找并定位代码中的错误。

    评论

报告相同问题?

悬赏问题

  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 如何提取csv文件中需要的列,将其整合为一篇完整文档,并进行jieba分词(语言-python)
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置