在MFC下,用ADO写了查询数据库中的一张表,并用ListCtrl显示查询结果,已经实现了查询,就是无法显示出来 20
查询成功的代码为:hr=m_pConnection->Execute("SELECT*FROMconnect",&RecordsAffected,adCmdText);i...
查询成功的代码为:
hr=m_pConnection->Execute("SELECT * FROM connect",&RecordsAffected,adCmdText);
if(SUCCEEDED(hr))
::AfxMessageBox(_T("查询表成功"));
m_pRecordset = m_pConnection->Execute("SELECT COUNT(*) FROM Staff",&RecordsAffected,adCmdText);
用ListCtrl显示的代码为
while(!m_pRecordset->adoEOF)
{
int i=0;
hr=m_pRecordset->MoveFirst();
_variant_t var;
CString strName=_T("");
CString strId=_T("");
var=m_pRecordset->GetCollect(_variant_t(_T("Name")));
if(var.vt!=VT_NULL)
{
strName=var.bstrVal;
}
else
{
strName=_T("");
}
var=m_pRecordset->GetCollect(_variant_t(_T("ID")));
if(var.vt!=VT_NULL)
{
strId=var.bstrVal;
}
else
{
strId=_T("");
}
CString strText=_T("");
strText.Format(_T("%s"),strName);
m_list.InsertItem(i,strText);
strText.Format(_T("%s"),strId);
m_list.SetItemText(i,1,strText);
i++;
m_pRecordset->MoveNext();
}
}
catch(_com_error e)
{::AfxMessageBox(_T("发生异常"));}
}
我的表很简单,,都是char类型的,如图 展开
hr=m_pConnection->Execute("SELECT * FROM connect",&RecordsAffected,adCmdText);
if(SUCCEEDED(hr))
::AfxMessageBox(_T("查询表成功"));
m_pRecordset = m_pConnection->Execute("SELECT COUNT(*) FROM Staff",&RecordsAffected,adCmdText);
用ListCtrl显示的代码为
while(!m_pRecordset->adoEOF)
{
int i=0;
hr=m_pRecordset->MoveFirst();
_variant_t var;
CString strName=_T("");
CString strId=_T("");
var=m_pRecordset->GetCollect(_variant_t(_T("Name")));
if(var.vt!=VT_NULL)
{
strName=var.bstrVal;
}
else
{
strName=_T("");
}
var=m_pRecordset->GetCollect(_variant_t(_T("ID")));
if(var.vt!=VT_NULL)
{
strId=var.bstrVal;
}
else
{
strId=_T("");
}
CString strText=_T("");
strText.Format(_T("%s"),strName);
m_list.InsertItem(i,strText);
strText.Format(_T("%s"),strId);
m_list.SetItemText(i,1,strText);
i++;
m_pRecordset->MoveNext();
}
}
catch(_com_error e)
{::AfxMessageBox(_T("发生异常"));}
}
我的表很简单,,都是char类型的,如图 展开
1个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询