代码如图所示:
_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 的调试工具来查找并定位代码中的错误。
解决 无用评论 打赏 举报
悬赏问题
- ¥20 idea运行测试代码报错问题
- ¥15 网络监控:网络故障告警通知
- ¥15 django项目运行报编码错误
- ¥15 请问这个是什么意思?
- ¥15 STM32驱动继电器
- ¥15 Windows server update services
- ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
- ¥15 模糊pid与pid仿真结果几乎一样
- ¥15 java的GUI的运用
- ¥15 我想付费需要AKM公司DSP开发资料及相关开发。