ado读取数据库

当我们在使用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);

你可能感兴趣的:(数据库,null)