constants.js 3.0 KB
Newer Older
S
StoneT2000 已提交
1 2 3 4
/**
 * Contains the the definitions/values assigned to various field types
 * @module FieldTypes
 */
5 6 7
/**
 * TDengine Field Types and their type codes
 * @typedef {Object} FieldTypes
S
StoneT2000 已提交
8
 * @global
9 10 11 12 13 14 15 16 17 18 19 20
 * @property {number} C_NULL - Null
 * @property {number} C_BOOL - Boolean. Note, 0x02 is the C_BOOL_NULL value.
 * @property {number} C_TINYINT - Tiny Int, values in the range [-2^7+1, 2^7-1]. Note, -2^7 has been used as the C_TINYINT_NULL value
 * @property {number} C_SMALLINT - Small Int, values in the range [-2^15+1, 2^15-1]. Note, -2^15 has been used as the C_SMALLINT_NULL value
 * @property {number} C_INT - Int, values in the range [-2^31+1, 2^31-1]. Note, -2^31 has been used as the C_INT_NULL value
 * @property {number} C_BIGINT - Big Int, values in the range [-2^59, 2^59].
 * @property {number} C_FLOAT - Float, values in the range [-3.4E38, 3.4E38], accurate up to 6-7 decimal places.
 * @property {number} C_DOUBLE - Double, values in the range [-1.7E308, 1.7E308], accurate up to 15-16 decimal places.
 * @property {number} C_BINARY - Binary, encoded in utf-8.
 * @property {number} C_TIMESTAMP - Timestamp in format "YYYY:MM:DD HH:MM:SS.MMM". Measured in number of milliseconds passed after
                                    1970-01-01 08:00:00.000 GMT.
 * @property {number} C_NCHAR - NChar field type encoded in ASCII, a wide string.
21 22
 *
 *
23 24 25
 *
 * @property {number} C_TIMESTAMP_MILLI - The code for millisecond timestamps, as returned by libtaos.taos_result_precision(result).
 * @property {number} C_TIMESTAMP_MICRO - The code for microsecond timestamps, as returned by libtaos.taos_result_precision(result).
26 27 28 29 30 31 32 33 34 35 36 37 38
 */
module.exports = {
    C_NULL : 0,
    C_BOOL : 1,
    C_TINYINT : 2,
    C_SMALLINT : 3,
    C_INT : 4,
    C_BIGINT : 5,
    C_FLOAT : 6,
    C_DOUBLE : 7,
    C_BINARY : 8,
    C_TIMESTAMP : 9,
    C_NCHAR : 10,
39 40 41 42
    C_TINYINT_UNSIGNED : 11,
    C_SMALLINT_UNSIGNED : 12,
    C_INT_UNSIGNED : 13,
    C_BIGINT_UNSIGNED : 14,
43 44
    // NULL value definition
    // NOTE: These values should change according to C definition in tsdb.h
45
    C_BOOL_NULL : 2,
46
    C_TINYINT_NULL : -128,
47
    C_TINYINT_UNSIGNED_NULL : 255,
48
    C_SMALLINT_NULL : -32768,
49
    C_SMALLINT_UNSIGNED_NULL : 65535,
50
    C_INT_NULL : -2147483648,
51 52 53
    C_INT_UNSIGNED_NULL : 4294967295,
    C_BIGINT_NULL : -9223372036854775808n,
    C_BIGINT_UNSIGNED_NULL : 18446744073709551615n,
54 55 56 57
    C_FLOAT_NULL : 2146435072,
    C_DOUBLE_NULL : -9223370937343148032,
    C_NCHAR_NULL : 4294967295,
    C_BINARY_NULL : 255,
58 59
    C_TIMESTAMP_MILLI : 0,
    C_TIMESTAMP_MICRO : 1,
S
StoneT2000 已提交
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
    getType,
}

const typeCodesToName = {
  0 : 'Null',
  1 : 'Boolean',
  2 : 'Tiny Int',
  3 : 'Small Int',
  4 : 'Int',
  5 : 'Big Int',
  6 : 'Float',
  7 : 'Double',
  8 : 'Binary',
  9 : 'Timestamp',
  10 : 'Nchar',
75 76 77 78
  11 : 'TINYINT_UNSIGNED',
  12 : 'SMALLINT_UNSIGNED',
  13 : 'INT_UNSIGNED',
  14 : 'BIGINT_UNSIGNED',
S
StoneT2000 已提交
79 80 81 82 83 84 85 86 87
}

/**
 * @function
 * @param {number} typecode - The code to get the name of the type for
 * @return {string} Name of the field type
 */
function getType(typecode) {
  return typeCodesToName[typecode];
88
}