业余码农 2013-06-17 02:19 采纳率: 0%
浏览 3062

VC++操作Access数据库的查询语句出错,求助

刚学着用VC++操作Acess2003数据库,在对话框里添加一个列表控件,然后把存到数据库里的内容在列表控件中显示,用编辑框向数据库添加内容,基本是照着书上写的做,除了名字改了其它程序都没动。现在向数据库添加内容没有问题,可以正常的存进去。但是想用查询语句SELECT * FROM CKdataInfo把数据库里的内容显示出来就出错了,具体程序如下
void Cdb003Dlg::FreshList()
{
try
{
//查询数据库中表的所有信息
//m_pRecordset->Open(_T("SELECT * FROM CKdataInfo"),(IDispatch*)m_pConnection,adOpenDynamic,adLockOptimistic,adCmdText);
//m_pRecordset->Open("SELECT * FROM CKdataInfo",this->m_pConnection.GetInterfacePtr(),adOpenStatic,adLockOptimistic,adCmdText);
m_pRecordset->Open("SELECT * FROM CKdataInfo", _variant_t((IDispatch*)m_pConnection,true), adOpenStatic,adLockOptimistic,adCmdText);
int nItem=1;
//清空ListCtrl控件中的所有数据
m_CKdata.DeleteAllItems();
while(!m_pRecordset->EndOfFile)
{
//得到控件中有多少记录
nItem=m_CKdata.GetItemCount();
CString str;
//获取记录中Time字段中的内容
str=(LPCTSTR)_bstr_t(m_pRecordset->GetCollect("序号"));
//插入字符串str到列表的第nItem行第一列中
m_CKdata.InsertItem(nItem,str);
//获取记录集中数据字段的内容
str=(LPCTSTR)_bstr_t(m_pRecordset->GetCollect("时间"));
//插入字符串str,设置控件中的第你nItem行第一列
m_CKdata.SetItemText(nItem,1,str);
//获取记录集中score字段的内容
str=(LPCTSTR)_bstr_t(m_pRecordset->GetCollect("数据"));
//插入字符串str,设置控件中的第nItem行第二列
m_CKdata.SetItemText(nItem,2,str);
m_pRecordset->MoveNext();
}
//关闭记录集
m_pRecordset->Close();
}
catch(_com_error e)
{
AfxMessageBox(_T("刷新列表失败!"));
//AfxMessageBox(e->ErrorMessage());
}
}
调试的时候加断点,发现就是在Open语句那里出错,但是又找不到错我在哪,比较头疼,请高手帮忙!!谢谢!!

  • 写回答

1条回答

  • lifanyong 2014-05-13 16:23
    关注

    open之前有没有执行“m_pRecordset.CreateInstance(__uuidof(Recordset));”这句?

    评论

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?