更新有问题

if(m_oDBMaster.QueryDataFromDataBase(strBufBit))
    {

     m_oDBMaster.AddRecord();
     _variant_t vtFld;

     vtFld.vt = VT_BSTR;
     vtFld.bstrVal =VarInfomation.m_VarName.AllocSysString();
     m_oDBMaster.SetField(1,vtFld);
     vtFld.bstrVal =VarInfomation.m_DeviceName.AllocSysString();
     m_oDBMaster.SetField(5,vtFld);//来自接口参数
     vtFld.bstrVal =VarInfomation.m_DeviceType.AllocSysString();
     m_oDBMaster.SetField(6,vtFld);
     vtFld.bstrVal =VarInfomation.m_RegisterName.AllocSysString();
     m_oDBMaster.SetField(7,vtFld);
     vtFld.bstrVal =VarInfomation.m_DataType.AllocSysString();
     m_oDBMaster.SetField(8,vtFld);
     //vtFld.bstrVal =szRWAttribute.AllocSysString();//deleted by lei.jin 2012/09/03
     //add by lei.jin 2012/09/03
     if ( VarInfomation.m_RWAttribute == 0 )
     {
      CString str("Write-Only");
      vtFld.bstrVal = str.AllocSysString();
     }
     else if ( VarInfomation.m_RWAttribute == 1 )
     {
      CString str("Read-Only");
      vtFld.bstrVal = str.AllocSysString();
     }
     else
     {
      CString str("Read-Write");
      vtFld.bstrVal = str.AllocSysString();
     }
     //add end by lei.jin  2012/09/03
     m_oDBMaster.SetField(9,vtFld);
     vtFld.vt=VT_I4;
     vtFld.lVal =VarInfomation.m_CollectFrequency;
     m_oDBMaster.SetField(10,vtFld);
     vtFld.vt = VT_BSTR;
     vtFld.bstrVal =AlarmGroup.AllocSysString();
     m_oDBMaster.SetField(12,vtFld);
     vtFld.bstrVal =szHistoryRecordWay.AllocSysString();
     m_oDBMaster.SetField(22,vtFld);
     vtFld.bstrVal =szSecurityArea.AllocSysString();
     m_oDBMaster.SetField(25,vtFld); 

     m_oDBMaster.Update();
     m_oDBMaster.CloseQuery();
    }

为啥移到更新的时候就出错呢?

inline HRESULT Recordset15::Update ( const _variant_t & Fields, const _variant_t & Values ) {
    HRESULT _hr = raw_Update(Fields, Values);
    if (FAILED(_hr)) _com_issue_errorex(_hr, this, __uuidof(this));
    return _hr;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值