代码如图所示:
_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;
}
求大佬解答是什么原因
关于C++ MFC编程 _ConnectionPtr指针连接数据库ACCESS的问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- lshen01 2023-03-15 19:00关注
参考GPT和自己的思路:
根据你的代码,可能导致程序中断的原因有以下几点:
- 数据库文件路径不正确。确保数据库文件路径是正确的,并且文件存在。
- 数据库连接字符串有误。具体的连接字符串应该根据你所使用的数据库版本来确定,如果使用的是Access 2007及以上版本,则连接字符串应该为:
"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C://Users//liu//Desktop//数据库1.accdb;Persist Security Info=False;"
- 数据库访问权限问题。如果你的数据库是受到保护的,则可能需要提供用户名和密码才能访问。在连接数据库时,应该提供正确的用户名和密码信息。
除此之外,还可能存在其他问题导致程序中断。在调试程序的过程中,可以使用 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如何配置