使用ADO操作数据库时一个好用的VARIANT类!

博客展示了一段代码,包含VTOCSTR函数、VTOLONG和VTODATE宏定义,以及CVar类的实现。该类继承自VARIANT,有多种构造和赋值操作。此为作者在MSDN中整理并增强的类,旨在帮助进行ADO操作数据库的人员。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

inline CString VTOCSTR(VARIANT *v)
{
if(v->vt==VT_BSTR)
{
CString str((LPCWSTR)v->bstrVal);
return str;
}
else
{
return CString("");
}
}

#define VTOLONG(v)((v).vt==VT_I4 ? (LONG)(v).lVal:0L)
#define VTODATE(v)((v).vt==VT_DATE ? (CTime)(v).iVal:0L)


class CVar : public VARIANT
{
public:
CVar()
{
VariantInit(this);
}
CVar(VARTYPE vt, SCODE scode = 0)
{
VariantInit(this);
this->vt = vt;
this->scode = scode;
}
CVar(VARIANT var)
{
*this = var;
}
~CVar()
{
VariantClear(this);
}

// ASSIGNMENT OPS.
CVar & operator=(PCWSTR pcwstr)
{
VariantClear(this);
if (NULL == (this->bstrVal = SysAllocStringLen(pcwstr, wcslen(pcwstr))))
throw E_OUTOFMEMORY;
this->vt = VT_BSTR;
return *this;
}
CVar & operator=(VARIANT var)
{
HRESULT hr;

VariantClear(this);
if (FAILED(hr = VariantCopy(this, &var)))
throw hr;
return *this;
}

.
operator STR() const
{
if(VT_BSTR == this->vt)
return this->bstrVal;
else
return NULL;
}

operator LONG() const
{
if (VT_I4 == this->vt)
return this->lVal;
else
return NULL;
}
operator DATE() const
{
if (VT_DATE == this->vt)
return this->date;
else
return NULL;
}
operator CY() const
{
COleCurrency cyNULL;
cyNULL.SetCurrency(0,0);
if (VT_CY == this->vt)
return this->cyVal;
else
return cyNULL;
}
HRESULT Clear()
{
return VariantClear(this);
}
};

这是我在MSDN中整理并增强的一个类,希望对进行ADO操作数据库的伙计们有所帮助!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值