2012-04-12 98 views
1

我在INT8类型的IBM Informix数据库中有一个字段可容纳20位数字。什么应该是MSVC++(RFX等效数据类型)中的等效数据类型?我使用的是Visual C++,而我的IDE是Visual Studio 6.0。IBM Informix数据库中INT8类型的RFX等效数据类型

领域initial_amount会声明如下:

RFX_Int64(pFX, _T("[initial_amount]"), m_initial_amount); 

我已经写了相同下面的自定义RFX定义代码。 但似乎有问题。

void AFXAPI RFX_Int64(CFieldExchange* pFX, LPCTSTR szName, __int64& value) 
{ 
    ASSERT(AfxIsValidAddress(pFX, sizeof(CFieldExchange))); 
    ASSERT(AfxIsValidString(szName)); 

    UINT nField; 
    if (!pFX->IsFieldType(&nField)) 
     return; 

    LONG* plLength = pFX->m_prs->GetFieldLengthBuffer(nField - 1, pFX->m_nFieldType); 
    switch (pFX->m_nOperation) 
    { 
    case CFieldExchange::BindFieldToColumn: 
      { 
#ifdef _DEBUG 
        // Assumes all bound fields BEFORE unbound fields 
        CODBCFieldInfo* pODBCInfo = 
          &pFX->m_prs->m_rgODBCFieldInfos[nField - 1]; 

        if (pODBCInfo->m_nSQLType != SQL_C_DOUBLE && 
          pODBCInfo->m_nSQLType != SQL_FLOAT) 
        { 
          // Warn of possible field schema mismatch 
          if (afxTraceFlags & traceDatabase) 
            TRACE1("Warning: double converted from SQL type %ld.\n", 
              pODBCInfo->m_nSQLType); 
        } 
#endif 
      } 
      // fall through 

    default: 
    LDefault: 
      pFX->Default(szName, &value, plLength, SQL_BIGINT , 
        sizeof(value), 22); 
      return; 

    case CFieldExchange::Fixup: 
      if (*plLength == SQL_NULL_DATA) 
      { 
        pFX->m_prs->SetNullFieldStatus(nField - 1); 
        value = afxDoublePseudoNull; 
      } 
      return; 

    case CFieldExchange::SetFieldNull: 
      if ((pFX->m_pvField == NULL && 
        pFX->m_nFieldType == CFieldExchange::outputColumn) || 
        pFX->m_pvField == &value) 
      { 
        if (pFX->m_bField) 
        { 
          pFX->m_prs->SetNullFieldStatus(nField - 1); 
          value = afxDoublePseudoNull; 
          *plLength = SQL_NULL_DATA; 
        } 
        else 
        { 
          pFX->m_prs->ClearNullFieldStatus(nField - 1); 
          *plLength = sizeof(value); 
        } 
#ifdef _DEBUG 
        pFX->m_nFieldFound = nField; 
#endif 
      } 
      return; 

    case CFieldExchange::MarkForAddNew: 
      // can force writing of psuedo-null value (as a non-null) by setting field dirty 
      if (value != afxDoublePseudoNull) 
      { 
        pFX->m_prs->SetDirtyFieldStatus(nField - 1); 
        pFX->m_prs->ClearNullFieldStatus(nField - 1); 
      } 
      return; 

    case CFieldExchange::MarkForUpdate: 
      if (value != afxDoublePseudoNull) 
        pFX->m_prs->ClearNullFieldStatus(nField - 1); 
      goto LDefault; 

case CFieldExchange::AllocCache: 
      { 
        CFieldInfo* pInfo = &pFX->m_prs->m_rgFieldInfos[nField - 1]; 
        pInfo->m_pvDataCache = new __int64; 
        pInfo->m_nDataType = AFX_RFX_DOUBLE; 
      } 
      return; 

#ifdef _DEBUG 
    // case CFieldExchange::DumpField: 
// { 
//  *pFX->m_pdcDump << "\n" << szName << " = " << value; 
// } 
      return; 
#endif //_DEBUG 

    } 
} 

此代码是否适用于Visual C++ 6.0?如果不是,那我该怎么办?

回答

1

您只能在INT8中存储19位数字,而不是20.如果您需要20位数字,请使用DECIMAL(20,0)。

你应该使用BIGINT而不是INT8; BIGINT在磁盘上占用8个字节,而INT8在磁盘上占用10个字节(不要求)。

这与您之前关于RFX和64位整数的两个问题有何不同?

  1. RFX_BigInt Error
  2. RFX Equivalent Data Type for __int64 in Informix

至于MS Visual C++ 6.0中有什么可能,对不起,我不知道。维基百科说它是在1998年发布的;这有点老,不是吗?有可能它不支持64位数据类型,这很可能是您使用64位数据类型时出现问题的原因。