Partilhar via


SQL para C: numérico

Os identificadores para os tipos de dados SQL ODBC numéricos são os seguintes:

  • SQL_DECIMAL
  • SQL_BIGINT
  • SQL_NUMERIC
  • SQL_REAL
  • SQL_TINYINT
  • SQL_FLOAT
  • SQL_SMALLINT
  • SQL_DOUBLE SQL_INTEGER

A tabela a seguir mostra os tipos de dados ODBC C para os quais os dados SQL numéricos podem ser convertidos. Para obter uma explicação das colunas e dos termos na tabela, consulte Convertendo dados de tipos de dados SQL para C.

Identificador de tipo C Teste * TargetValuePtr * Strlen_or_indptr SQLSTATE
SQL_C_CHAR BufferLength de comprimento <de byte de caractere

Número de dígitos inteiros (em vez de fracionários<) BufferLength

Número de dígitos inteiros (em vez de fracionários >) = BufferLength
Dados

Dados truncados

Indefinido
Comprimento dos dados em bytes

Comprimento dos dados em bytes

Indefinido
n/d

01004

22003
SQL_C_WCHAR BufferLength de comprimento de caractere <

Número de dígitos inteiros (em vez de fracionários<) BufferLength

Número de dígitos inteiros (em vez de fracionários >) = BufferLength
Dados

Dados truncados

Indefinido
Comprimento dos dados em caracteres

Comprimento dos dados em caracteres

Indefinido
n/d

01004

22003
SQL_C_STINYINT

SQL_C_UTINYINT

SQL_C_TINYINT

SQL_C_SBIGINT

SQL_C_UBIGINT

SQL_C_SSHORT

SQL_C_USHORT

SQL_C_SHORT

SQL_C_SLONG

SQL_C_ULONG

SQL_C_LONG

SQL_C_NUMERIC
Dados convertidos sem truncamento[a]

Dados convertidos com truncamento de dígitos fracionários[a]

A conversão de dados resultaria em perda de dígitos inteiros (em vez de fracionários) [a]
Dados

Dados truncados

Indefinido
Tamanho do tipo de dados C

Tamanho do tipo de dados C

Indefinido
n/d

01S07

22003
SQL_C_FLOAT

SQL_C_DOUBLE
Os dados estão dentro do intervalo do tipo de dados no qual o número está sendo convertido[a]

Os dados estão fora do intervalo do tipo de dados no qual o número está sendo convertido[a]
Dados

Indefinido
Tamanho do tipo de dados C

Indefinido
n/d

22003
SQL_C_BIT Os dados são 0 ou 1[a]

Os dados são maiores que 0, menores que 2 e não são iguais a 1[a]

Os dados são menores que 0 ou maiores ou iguais a 2[a]
Dados

Dados truncados

Indefinido
1[b]

1[b]

Indefinido
n/d

01S07

22003
SQL_C_BINARY Comprimento de bytes de dados <= BufferLength

Comprimento de byte de buffer de dadosLength>
Dados

Indefinido
Comprimento dos dados

Indefinido
n/d

22003
SQL_C_INTERVAL_MONTH[c] SQL_C_INTERVAL_YEAR[c] SQL_C_INTERVAL_DAY[c] SQL_C_INTERVAL_HOUR[c] SQL_C_INTERVAL_MINUTE[c] SQL_C_INTERVAL_SECOND[c] Dados não truncados

Parte de segundos fracionários truncada

Parte inteira do número truncado
Dados

Dados truncados

Indefinido
Comprimento dos dados em bytes

Comprimento dos dados em bytes

Indefinido
n/d

01S07

22015
SQL_C_INTERVAL_YEAR_TO_MONTH SQL_C_INTERVAL_DAY_TO_HOUR SQL_C_INTERVAL_DAY_TO_MINUTE SQL_C_INTERVAL_DAY_TO_SECOND SQL_C_INTERVAL_HOUR_TO_MINUTE SQL_C_INTERVAL_HOUR_TO_SECOND Parte inteira do número truncado Indefinido Indefinido 22015

[a] O valor de BufferLength é ignorado para essa conversão. O driver pressupõe que o tamanho de *TargetValuePtr seja o tamanho do tipo de dados C.

[b] Esse é o tamanho do tipo de dados C correspondente.

[c] Essa conversão tem suporte apenas para os tipos de dados numéricos exatos (SQL_DECIMAL, SQL_NUMERIC, SQL_TINYINT, SQL_SMALLINT, SQL_INTEGER e SQL_BIGINT). Não há suporte para os tipos de dados numéricos aproximados (SQL_REAL, SQL_FLOAT ou SQL_DOUBLE).

SQL_C_NUMERIC e SQLSetDescField

A função SQLSetDescField é necessária para executar a associação manual com valores SQL_C_NUMERIC. (Observe que SQLSetDescField foi adicionado no ODBC 3.0.) Para executar a associação manual, primeiro você deve obter o identificador do descritor.

if (fCType == SQL_C_NUMERIC) {   
   // special processing required for NUMERIC to get right scale & precision  
   // Modify the fields in the implicit application parameter descriptor  
   SQLHDESC hdesc=NULL;  
  
   // Use SQL_ATTR_APP_ROW_DESC for calls to SQLBindCol()  
   // Use SQL_ATTR_APP_PARAM_DESC for calls to SQLBindParameter()  
   //  
   // retcode = SQLGetStmtAttr(hstmt, SQL_ATTR_APP_ROW_DESC, &hdesc, 0, NULL);  
   retcode = SQLGetStmtAttr(hstmt, SQL_ATTR_APP_PARAM_DESC, &hdesc, 0, NULL);  
   if (!ODBC_CALL_SUCCESS(retcode)) {  
      printf ("\nSQLGetStmtAttr failed");  
      i = 1;  
      sqlstate[7] = '\0';  
      while (SQLGetDiagRec(SQL_HANDLE_STMT, hstmt, i, sqlstate, &NativeError, wrkbuf, sizeof(wrkbuf), &len) != SQL_NO_DATA) {  
         printf("\niTestCase = %d Failed...Precision = %d, Scale = %d\nNativeError=%d, State=%s, \n  Message=%s",   
            iTestCase, Precision, Scale, NativeError, sqlstate, wrkbuf);  
         i++;  
      }  
      continue;  
   }  
   retcode = SQLSetDescField(hdesc, iCol, SQL_DESC_TYPE, (SQLPOINTER) SQL_C_NUMERIC, 0);  
   if (!ODBC_CALL_SUCCESS(retcode))  
      goto error;  
   retcode = SQLSetDescField(hdesc, iCol, SQL_DESC_PRECISION, (SQLPOINTER)num.precision, 0);  
   if (!ODBC_CALL_SUCCESS(retcode))  
      goto error;  
   retcode = SQLSetDescField(hdesc, iCol, SQL_DESC_SCALE, (SQLPOINTER)num.scale, 0);  
   if (!ODBC_CALL_SUCCESS(retcode))  
      goto error;  
   retcode = SQLSetDescField(hdesc, iCol, SQL_DESC_DATA_PTR, (SQLPOINTER) &(num), sizeof(num));