当我们在使用ado操作数据库的时候经常会碰到一些问题!例如数据库为空我们就应该对是否为空做出判断!
_variant_t var;
var =(_bstr_t)m_pRecordSet->GetCollect("z_ControllerSN");
if(var.vt != VT_NULL)
{
m_ControllerSN=(char*)(_bstr_t)var;
}
else
{
m_ControllerSN="";
}
m_list.SetItemText(nItem,1,m_ControllerSN);
例如这段代码就进行了判断!但是这种判断方法还是有错误的!为什么呢!
主要的原因在于我们判断数据库为空是因为GetCollect()这个函数的返回值是否为空!
当该值为空时就不能进行类型转换了!否则程序会报错!
所以我们不能为了省事而像上面这样去写ado操作数据库的读操作!
进行判断后在类型转换如下:
_variant_t var;
var =m_pRecordSet->GetCollect("z_ControllerSN");
if(var.vt != VT_NULL)
{
m_ControllerSN=(LPCTSTR)(_bstr_t)var;
}
else
{
m_ControllerSN="";
}
m_list.SetItemText(nItem,1,m_ControllerSN);