COleVariant类

http://topic.csdn.net/t/20010703/09/179360.html

COleVariant 封装了VARIANT。  
   
  m_pUsersSet   =   new   CDaoRecordset(   m_pDB   );  
  strSQL.Format(   _T("select   *   from   [Users]   where   LoginName   =   /'%s/'"),   strLoginName   );  
  m_pUsersSet->Open(   dbOpenDynaset,   strSQL   );  
  m_pUsersSet->GetFieldValue(   _T("Password"),   varValue   );  
  strTemp   =   varValue.bstrVal;                       //   想要啥就选啥,当然不是每中类型都有值   
  

 

http://www.china-askpro.com/msg25/qa11.shtml

实际的数据就在 VARIANT 结构中。
    使用 COleVariant 的两个操作
    operator LPCVARIANT
     Converts a COleVariant value into an LPCVARIANT.
    operator LPVARIANT
     Converts a COleVariant object into an LPVARIANT.
    可以得到 VARIANT 结构。其区别是,前者是个拷贝操作,将 VARIANT 结构的内容拷贝到目标中去,后者仅仅返回
    VARIANT 结构的指针。不管那种情况,现在我们都能访问到 VARIANT 所包含的数据了。余下的问题是如何解释数
    据内容。
    VARIANT 结构包含两部分。其一是 VARTYPE 型的成员变量vt;其二是个联合类型,这个联合包含了VC常用的几乎所有类型。因为联合用的是相同的存储空间,因此对联合的内容的解释依赖于 vt。
    例如,
    若 vt 的值是 VT_UI2, 说明该联合被解释为short int. 并使用成员变量名 iVal。
    若 vt 的的值是 VT_BSTR,说明该联合被解释为 BSTR 类型。并使用成员变量名 bstrVal。
    若 vt 的的值是 VT_BSTR|VT_BYREF,说明该联合被解释为BSTR 型指针。并使用成员变量名 pbstrVal。
    (其他详见 VARIANT 的联机帮助)
    *********************************
    若从数据库返回的是简单类型,如 short, long, 等,则直接引用既可。(主持人注:COleVariant类重载了“=”操作符,所以常用类型可以直接转换)若返回的是字符串类型,则有可能是 bstrVal 或pbstrVal。依赖于数据库服务程序。 BSTR 实际上就是个unicode 字符串,CString 的构造函数和赋值操作都能直接识别这一类型。
    
    AndySun问:
    VARIANT结构的vt成员可以为值VT_DECIMAL,当然,这个值在MSDN的帮助中似乎没有,但在VARIANT定义的源文件中确实有它的定义,它是在wtypes.h文件中定义的。但我不明白怎样将VT_DECIMAL的数据转换成常用的C数据类型,更想知道 VT_DECIMAL中究竟存放的是一个怎样的数据,应怎样将这个数据显示出来。谢谢!
    李海答:你可以使用COleVariant的ChangeType函数(相当于API函数VariantChangeType)将VT_DECIMAL转换为其他常用类型。

此问题由曾侃回答。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值