tvariant.c 29.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

S
common  
Shengliang Guan 已提交
16 17
#define _DEFAULT_SOURCE
#include "tvariant.h"
18
#include "ttime.h"
19
#include "ttokendef.h"
20
#include "tvariant.h"
21

22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
#define SET_EXT_INFO(converted, res, minv, maxv, exti)              \
  do {                                                              \
    if (converted == NULL || exti == NULL || *converted == false) { \
      break;                                                        \
    }                                                               \
    if ((res) < (minv)) {                                           \
      *exti = -1;                                                   \
      break;                                                        \
    }                                                               \
    if ((res) > (maxv)) {                                           \
      *exti = 1;                                                    \
      break;                                                        \
    }                                                               \
    assert(0);                                                      \
  } while (0)
37

X
Xiaoyu Wang 已提交
38
int32_t toInteger(const char *z, int32_t n, int32_t base, int64_t *value) {
39
  errno = 0;
X
Xiaoyu Wang 已提交
40
  char *endPtr = NULL;
41

wafwerar's avatar
wafwerar 已提交
42
  *value = taosStr2Int64(z, &endPtr, base);
X
Xiaoyu Wang 已提交
43
  if (errno == ERANGE || errno == EINVAL || endPtr - z != n) {
44 45 46 47 48 49 50
    errno = 0;
    return -1;
  }

  return 0;
}

X
Xiaoyu Wang 已提交
51 52 53
int32_t toUInteger(const char *z, int32_t n, int32_t base, uint64_t *value) {
  errno = 0;
  char *endPtr = NULL;
54

X
Xiaoyu Wang 已提交
55 56 57 58 59
  const char *p = z;
  while (*p != 0 && *p == ' ') p++;
  if (*p != 0 && *p == '-') {
    return -1;
  }
X
Xiaoyu Wang 已提交
60

wafwerar's avatar
wafwerar 已提交
61
  *value = taosStr2UInt64(z, &endPtr, base);
X
Xiaoyu Wang 已提交
62 63 64
  if (errno == ERANGE || errno == EINVAL || endPtr - z != n) {
    errno = 0;
    return -1;
65
  }
X
Xiaoyu Wang 已提交
66

X
Xiaoyu Wang 已提交
67
  return 0;
68
}
H
Haojun Liao 已提交
69

70
/**
H
Haojun Liao 已提交
71
 * create SVariant from binary string, not ascii data
72 73 74 75 76
 * @param pVar
 * @param pz
 * @param len
 * @param type
 */
H
Haojun Liao 已提交
77
void taosVariantCreateFromBinary(SVariant *pVar, const char *pz, size_t len, uint32_t type) {
78 79 80
  switch (type) {
    case TSDB_DATA_TYPE_BOOL:
    case TSDB_DATA_TYPE_TINYINT: {
81
      pVar->nLen = tDataTypes[type].bytes;
82
      pVar->i = GET_INT8_VAL(pz);
83 84 85
      break;
    }
    case TSDB_DATA_TYPE_UTINYINT: {
86
      pVar->nLen = tDataTypes[type].bytes;
87
      pVar->u = GET_UINT8_VAL(pz);
88 89 90
      break;
    }
    case TSDB_DATA_TYPE_SMALLINT: {
91
      pVar->nLen = tDataTypes[type].bytes;
92
      pVar->i = GET_INT16_VAL(pz);
93 94 95
      break;
    }
    case TSDB_DATA_TYPE_USMALLINT: {
96
      pVar->nLen = tDataTypes[type].bytes;
97
      pVar->u = GET_UINT16_VAL(pz);
98 99 100
      break;
    }
    case TSDB_DATA_TYPE_INT: {
101
      pVar->nLen = tDataTypes[type].bytes;
102
      pVar->i = GET_INT32_VAL(pz);
103 104 105
      break;
    }
    case TSDB_DATA_TYPE_UINT: {
106
      pVar->nLen = tDataTypes[type].bytes;
107
      pVar->u = GET_UINT32_VAL(pz);
108 109 110 111
      break;
    }
    case TSDB_DATA_TYPE_BIGINT:
    case TSDB_DATA_TYPE_TIMESTAMP: {
112
      pVar->nLen = tDataTypes[type].bytes;
113
      pVar->i = GET_INT64_VAL(pz);
114 115 116
      break;
    }
    case TSDB_DATA_TYPE_UBIGINT: {
117
      pVar->nLen = tDataTypes[type].bytes;
118
      pVar->u = GET_UINT64_VAL(pz);
119 120 121
      break;
    }
    case TSDB_DATA_TYPE_DOUBLE: {
122
      pVar->nLen = tDataTypes[type].bytes;
H
Haojun Liao 已提交
123
      pVar->d = GET_DOUBLE_VAL(pz);
124 125 126
      break;
    }
    case TSDB_DATA_TYPE_FLOAT: {
127
      pVar->nLen = tDataTypes[type].bytes;
H
Haojun Liao 已提交
128
      pVar->d = GET_FLOAT_VAL(pz);
129 130
      break;
    }
X
Xiaoyu Wang 已提交
131
    case TSDB_DATA_TYPE_NCHAR: {  // here we get the nchar length from raw binary bits length
132
      size_t lenInwchar = len / TSDB_NCHAR_SIZE;
133

wafwerar's avatar
wafwerar 已提交
134
      pVar->ucs4 = taosMemoryCalloc(1, (lenInwchar + 1) * TSDB_NCHAR_SIZE);
wafwerar's avatar
wafwerar 已提交
135
      memcpy(pVar->ucs4, pz, lenInwchar * TSDB_NCHAR_SIZE);
136
      pVar->nLen = (int32_t)len;
X
Xiaoyu Wang 已提交
137

138 139
      break;
    }
140
    case TSDB_DATA_TYPE_BINARY: {  // todo refactor, extract a method
wafwerar's avatar
wafwerar 已提交
141
      pVar->pz = taosMemoryCalloc(len + 1, sizeof(char));
142
      memcpy(pVar->pz, pz, len);
143
      pVar->nLen = (int32_t)len;
144 145
      break;
    }
X
Xiaoyu Wang 已提交
146

147
    default:
148
      pVar->i = GET_INT32_VAL(pz);
149
      pVar->nLen = tDataTypes[TSDB_DATA_TYPE_INT].bytes;
150
  }
X
Xiaoyu Wang 已提交
151

152 153 154
  pVar->nType = type;
}

H
Haojun Liao 已提交
155
void taosVariantDestroy(SVariant *pVar) {
156
  if (pVar == NULL) return;
X
Xiaoyu Wang 已提交
157

158
  if (pVar->nType == TSDB_DATA_TYPE_BINARY || pVar->nType == TSDB_DATA_TYPE_NCHAR) {
wafwerar's avatar
wafwerar 已提交
159
    taosMemoryFreeClear(pVar->pz);
160 161
    pVar->nLen = 0;
  }
weixin_48148422's avatar
weixin_48148422 已提交
162 163

  // NOTE: this is only for string array
W
wpan 已提交
164
  if (pVar->nType == TSDB_DATA_TYPE_POINTER_ARRAY) {
weixin_48148422's avatar
weixin_48148422 已提交
165
    size_t num = taosArrayGetSize(pVar->arr);
X
Xiaoyu Wang 已提交
166 167
    for (size_t i = 0; i < num; i++) {
      void *p = taosArrayGetP(pVar->arr, i);
wafwerar's avatar
wafwerar 已提交
168
      taosMemoryFree(p);
weixin_48148422's avatar
weixin_48148422 已提交
169 170 171
    }
    taosArrayDestroy(pVar->arr);
    pVar->arr = NULL;
W
wpan 已提交
172 173 174
  } else if (pVar->nType == TSDB_DATA_TYPE_VALUE_ARRAY) {
    taosArrayDestroy(pVar->arr);
    pVar->arr = NULL;
weixin_48148422's avatar
weixin_48148422 已提交
175
  }
176 177
}

H
Haojun Liao 已提交
178
bool taosVariantIsValid(SVariant *pVar) {
179 180 181 182
  assert(pVar != NULL);
  return isValidDataType(pVar->nType);
}

H
Haojun Liao 已提交
183
void taosVariantAssign(SVariant *pDst, const SVariant *pSrc) {
184
  if (pSrc == NULL || pDst == NULL) return;
X
Xiaoyu Wang 已提交
185

H
Haojun Liao 已提交
186
  pDst->nType = pSrc->nType;
H
Haojun Liao 已提交
187
  if (pSrc->nType == TSDB_DATA_TYPE_BINARY || pSrc->nType == TSDB_DATA_TYPE_NCHAR) {
H
Haojun Liao 已提交
188
    int32_t len = pSrc->nLen + TSDB_NCHAR_SIZE;
wafwerar's avatar
wafwerar 已提交
189
    char   *p = taosMemoryRealloc(pDst->pz, len);
H
Haojun Liao 已提交
190 191
    assert(p);

H
Haojun Liao 已提交
192
    memset(p, 0, len);
H
Haojun Liao 已提交
193 194
    pDst->pz = p;

H
Haojun Liao 已提交
195 196
    memcpy(pDst->pz, pSrc->pz, pSrc->nLen);
    pDst->nLen = pSrc->nLen;
H
Haojun Liao 已提交
197 198 199
    return;
  }

200
  if (IS_NUMERIC_TYPE(pSrc->nType) || (pSrc->nType == TSDB_DATA_TYPE_BOOL)) {
201
    pDst->i = pSrc->i;
W
wpan 已提交
202
  } else if (pSrc->nType == TSDB_DATA_TYPE_POINTER_ARRAY) {  // this is only for string array
weixin_48148422's avatar
weixin_48148422 已提交
203
    size_t num = taosArrayGetSize(pSrc->arr);
X
Xiaoyu Wang 已提交
204 205 206 207
    pDst->arr = taosArrayInit(num, sizeof(char *));
    for (size_t i = 0; i < num; i++) {
      char *p = (char *)taosArrayGetP(pSrc->arr, i);
      char *n = strdup(p);
weixin_48148422's avatar
weixin_48148422 已提交
208 209
      taosArrayPush(pDst->arr, &n);
    }
W
wpan 已提交
210
  } else if (pSrc->nType == TSDB_DATA_TYPE_VALUE_ARRAY) {
X
Xiaoyu Wang 已提交
211 212 213 214 215 216 217 218
    size_t num = taosArrayGetSize(pSrc->arr);
    pDst->arr = taosArrayInit(num, sizeof(int64_t));
    pDst->nLen = pSrc->nLen;
    assert(pSrc->nLen == num);
    for (size_t i = 0; i < num; i++) {
      int64_t *p = taosArrayGet(pSrc->arr, i);
      taosArrayPush(pDst->arr, p);
    }
219
  }
H
Haojun Liao 已提交
220

W
wpan 已提交
221
  if (pDst->nType != TSDB_DATA_TYPE_POINTER_ARRAY && pDst->nType != TSDB_DATA_TYPE_VALUE_ARRAY) {
H
Haojun Liao 已提交
222
    pDst->nLen = tDataTypes[pDst->nType].bytes;
H
Haojun Liao 已提交
223
  }
224 225
}

X
Xiaoyu Wang 已提交
226
int32_t taosVariantCompare(const SVariant *p1, const SVariant *p2) {
H
Haojun Liao 已提交
227 228 229 230 231 232 233 234 235 236 237
  if (p1->nType == TSDB_DATA_TYPE_NULL && p2->nType == TSDB_DATA_TYPE_NULL) {
    return 0;
  }

  if (p1->nType == TSDB_DATA_TYPE_NULL) {
    return -1;
  }

  if (p2->nType == TSDB_DATA_TYPE_NULL) {
    return 1;
  }
238

239 240 241 242
  if (p1->nType == TSDB_DATA_TYPE_BINARY || p1->nType == TSDB_DATA_TYPE_NCHAR) {
    if (p1->nLen == p2->nLen) {
      return memcmp(p1->pz, p2->pz, p1->nLen);
    } else {
X
Xiaoyu Wang 已提交
243
      return p1->nLen > p2->nLen ? 1 : -1;
244 245
    }
  } else if (p1->nType == TSDB_DATA_TYPE_FLOAT || p1->nType == TSDB_DATA_TYPE_DOUBLE) {
H
Haojun Liao 已提交
246
    if (p1->d == p2->d) {
247 248
      return 0;
    } else {
X
Xiaoyu Wang 已提交
249
      return p1->d > p2->d ? 1 : -1;
250 251
    }
  } else if (IS_UNSIGNED_NUMERIC_TYPE(p1->nType)) {
252
    if (p1->u == p2->u) {
253 254
      return 0;
    } else {
X
Xiaoyu Wang 已提交
255
      return p1->u > p2->u ? 1 : -1;
256 257
    }
  } else {
258
    if (p1->i == p2->i) {
259 260
      return 0;
    } else {
X
Xiaoyu Wang 已提交
261
      return p1->i > p2->i ? 1 : -1;
262
    }
263 264 265
  }
}

H
Haojun Liao 已提交
266
int32_t taosVariantToString(SVariant *pVar, char *dst) {
267
  if (pVar == NULL || dst == NULL) return 0;
X
Xiaoyu Wang 已提交
268

269 270 271 272 273 274
  switch (pVar->nType) {
    case TSDB_DATA_TYPE_BINARY: {
      int32_t len = sprintf(dst, "\'%s\'", pVar->pz);
      assert(len <= pVar->nLen + sizeof("\'") * 2);  // two more chars
      return len;
    }
X
Xiaoyu Wang 已提交
275

276 277
    case TSDB_DATA_TYPE_NCHAR: {
      dst[0] = '\'';
wafwerar's avatar
wafwerar 已提交
278
      taosUcs4ToMbs(pVar->ucs4, (taosUcs4len(pVar->ucs4) + 1) * TSDB_NCHAR_SIZE, dst + 1);
279
      int32_t len = (int32_t)strlen(dst);
280 281 282 283
      dst[len] = '\'';
      dst[len + 1] = 0;
      return len + 1;
    }
X
Xiaoyu Wang 已提交
284

285 286 287 288
    case TSDB_DATA_TYPE_BOOL:
    case TSDB_DATA_TYPE_TINYINT:
    case TSDB_DATA_TYPE_SMALLINT:
    case TSDB_DATA_TYPE_INT:
289 290 291
    case TSDB_DATA_TYPE_UTINYINT:
    case TSDB_DATA_TYPE_USMALLINT:
    case TSDB_DATA_TYPE_UINT:
292
      return sprintf(dst, "%d", (int32_t)pVar->i);
X
Xiaoyu Wang 已提交
293

294
    case TSDB_DATA_TYPE_BIGINT:
295
      return sprintf(dst, "%" PRId64, pVar->i);
296
    case TSDB_DATA_TYPE_UBIGINT:
297
      return sprintf(dst, "%" PRIu64, pVar->u);
298 299
    case TSDB_DATA_TYPE_FLOAT:
    case TSDB_DATA_TYPE_DOUBLE:
H
Haojun Liao 已提交
300
      return sprintf(dst, "%.9lf", pVar->d);
X
Xiaoyu Wang 已提交
301

302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318
    default:
      return 0;
  }
}

static FORCE_INLINE int32_t convertToBoolImpl(char *pStr, int32_t len) {
  if ((strncasecmp(pStr, "true", len) == 0) && (len == 4)) {
    return TSDB_TRUE;
  } else if ((strncasecmp(pStr, "false", len) == 0) && (len == 5)) {
    return TSDB_FALSE;
  } else if (strcasecmp(pStr, TSDB_DATA_NULL_STR_L) == 0) {
    return TSDB_DATA_BOOL_NULL;
  } else {
    return -1;
  }
}

wafwerar's avatar
wafwerar 已提交
319
static FORCE_INLINE int32_t wcsconvertToBoolImpl(TdUcs4 *pstr, int32_t len) {
320 321 322 323
  if ((wcsncasecmp(pstr, L"true", len) == 0) && (len == 4)) {
    return TSDB_TRUE;
  } else if (wcsncasecmp(pstr, L"false", len) == 0 && (len == 5)) {
    return TSDB_FALSE;
324 325
  } else if (memcmp(pstr, L"null", wcslen(L"null")) == 0) {
    return TSDB_DATA_BOOL_NULL;
326 327 328 329 330
  } else {
    return -1;
  }
}

H
Haojun Liao 已提交
331
static int32_t toBinary(SVariant *pVariant, char **pDest, int32_t *pDestSize) {
332
  const int32_t INITIAL_ALLOC_SIZE = 40;
X
Xiaoyu Wang 已提交
333
  char         *pBuf = NULL;
334

H
Haojun Liao 已提交
335
  // it is a in-place convert type for SVariant, local buffer is needed
336
  if (*pDest == pVariant->pz) {
wafwerar's avatar
wafwerar 已提交
337
    pBuf = taosMemoryCalloc(1, INITIAL_ALLOC_SIZE);
338
  }
X
Xiaoyu Wang 已提交
339

340 341 342
  if (pVariant->nType == TSDB_DATA_TYPE_NCHAR) {
    size_t newSize = pVariant->nLen * TSDB_NCHAR_SIZE;
    if (pBuf != NULL) {
dengyihao's avatar
dengyihao 已提交
343
      if (newSize >= INITIAL_ALLOC_SIZE) {
wafwerar's avatar
wafwerar 已提交
344
        pBuf = taosMemoryRealloc(pBuf, newSize + 1);
345
      }
X
Xiaoyu Wang 已提交
346

wafwerar's avatar
wafwerar 已提交
347
      taosUcs4ToMbs(pVariant->ucs4, (int32_t)newSize, pBuf);
wafwerar's avatar
wafwerar 已提交
348
      taosMemoryFree(pVariant->ucs4);
349 350
      pBuf[newSize] = 0;
    } else {
wafwerar's avatar
wafwerar 已提交
351
      taosUcs4ToMbs(pVariant->ucs4, (int32_t)newSize, *pDest);
352
    }
X
Xiaoyu Wang 已提交
353

354
  } else {
355
    if (IS_SIGNED_NUMERIC_TYPE(pVariant->nType)) {
356
      sprintf(pBuf == NULL ? *pDest : pBuf, "%" PRId64, pVariant->i);
357
    } else if (pVariant->nType == TSDB_DATA_TYPE_DOUBLE || pVariant->nType == TSDB_DATA_TYPE_FLOAT) {
H
Haojun Liao 已提交
358
      sprintf(pBuf == NULL ? *pDest : pBuf, "%lf", pVariant->d);
359
    } else if (pVariant->nType == TSDB_DATA_TYPE_BOOL) {
360
      sprintf(pBuf == NULL ? *pDest : pBuf, "%s", (pVariant->i == TSDB_TRUE) ? "TRUE" : "FALSE");
361 362 363 364
    } else if (pVariant->nType == 0) {  // null data
      setNull(pBuf == NULL ? *pDest : pBuf, TSDB_DATA_TYPE_BINARY, 0);
    }
  }
X
Xiaoyu Wang 已提交
365

366 367 368
  if (pBuf != NULL) {
    *pDest = pBuf;
  }
X
Xiaoyu Wang 已提交
369

370
  *pDestSize = (int32_t)strlen(*pDest);
371 372 373
  return 0;
}

H
Haojun Liao 已提交
374
static int32_t toNchar(SVariant *pVariant, char **pDest, int32_t *pDestSize) {
375
  char tmpBuf[40] = {0};
X
Xiaoyu Wang 已提交
376 377

  char   *pDst = tmpBuf;
378
  int32_t nLen = 0;
379 380 381

  // convert the number to string, than convert it to wchar string.
  if (IS_SIGNED_NUMERIC_TYPE(pVariant->nType)) {
382
    nLen = sprintf(pDst, "%" PRId64, pVariant->i);
383
  } else if (IS_UNSIGNED_NUMERIC_TYPE(pVariant->nType)) {
X
Xiaoyu Wang 已提交
384
    nLen = sprintf(pDst, "%" PRIu64, pVariant->u);
385
  } else if (pVariant->nType == TSDB_DATA_TYPE_DOUBLE || pVariant->nType == TSDB_DATA_TYPE_FLOAT) {
H
Haojun Liao 已提交
386
    nLen = sprintf(pDst, "%lf", pVariant->d);
387 388 389 390
  } else if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
    pDst = pVariant->pz;
    nLen = pVariant->nLen;
  } else if (pVariant->nType == TSDB_DATA_TYPE_BOOL) {
391
    nLen = sprintf(pDst, "%s", (pVariant->i == TSDB_TRUE) ? "TRUE" : "FALSE");
392
  }
X
Xiaoyu Wang 已提交
393

394
  if (*pDest == pVariant->pz) {
wafwerar's avatar
wafwerar 已提交
395
    TdUcs4 *pWStr = taosMemoryCalloc(1, (nLen + 1) * TSDB_NCHAR_SIZE);
X
Xiaoyu Wang 已提交
396
    bool    ret = taosMbsToUcs4(pDst, nLen, pWStr, (nLen + 1) * TSDB_NCHAR_SIZE, NULL);
397
    if (!ret) {
wafwerar's avatar
wafwerar 已提交
398
      taosMemoryFreeClear(pWStr);
399 400 401
      return -1;
    }

402 403
    // free the binary buffer in the first place
    if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
wafwerar's avatar
wafwerar 已提交
404
      taosMemoryFree(pVariant->ucs4);
405
    }
X
Xiaoyu Wang 已提交
406

wafwerar's avatar
wafwerar 已提交
407 408
    pVariant->ucs4 = pWStr;
    *pDestSize = taosUcs4len(pVariant->ucs4);
X
Xiaoyu Wang 已提交
409

410
    // shrink the allocate memory, no need to check here.
wafwerar's avatar
wafwerar 已提交
411
    char *tmp = taosMemoryRealloc(pVariant->ucs4, (*pDestSize + 1) * TSDB_NCHAR_SIZE);
412
    assert(tmp != NULL);
X
Xiaoyu Wang 已提交
413

wafwerar's avatar
wafwerar 已提交
414
    pVariant->ucs4 = (TdUcs4 *)tmp;
415
  } else {
416
    int32_t output = 0;
417

X
Xiaoyu Wang 已提交
418
    bool ret = taosMbsToUcs4(pDst, nLen, (TdUcs4 *)*pDest, (nLen + 1) * TSDB_NCHAR_SIZE, &output);
419 420 421 422
    if (!ret) {
      return -1;
    }

H
hjxilinx 已提交
423
    if (pDestSize != NULL) {
424
      *pDestSize = output;
H
hjxilinx 已提交
425
    }
426
  }
X
Xiaoyu Wang 已提交
427

428 429 430 431
  return 0;
}

static FORCE_INLINE int32_t convertToDouble(char *pStr, int32_t len, double *value) {
X
Xiaoyu Wang 已提交
432 433 434 435 436
  //  SToken stoken = {.z = pStr, .n = len};
  //  if (TK_ILLEGAL == tGetNumericStringType(&stoken)) {
  //    return -1;
  //  }
  //
wafwerar's avatar
wafwerar 已提交
437
  //  *value = taosStr2Double(pStr, NULL);
438 439 440
  return 0;
}

X
Xiaoyu Wang 已提交
441 442
static FORCE_INLINE int32_t convertToInteger(SVariant *pVariant, int64_t *result, int32_t type, bool issigned,
                                             bool releaseVariantPtr, bool *converted) {
443
  if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
H
Haojun Liao 已提交
444
    setNull((char *)result, type, tDataTypes[type].bytes);
445 446
    return 0;
  }
447 448 449 450 451 452

  if (IS_SIGNED_NUMERIC_TYPE(pVariant->nType) || (pVariant->nType == TSDB_DATA_TYPE_BOOL)) {
    *result = pVariant->i;
  } else if (IS_UNSIGNED_NUMERIC_TYPE(pVariant->nType)) {
    *result = pVariant->u;
  } else if (IS_FLOAT_TYPE(pVariant->nType)) {
X
Xiaoyu Wang 已提交
453
    *result = (int64_t)pVariant->d;
454
  } else {
X
Xiaoyu Wang 已提交
455
    // TODO: handling var types
456
  }
H
Haojun Liao 已提交
457
#if 0
458
  errno = 0;
D
fix bug  
dapan1121 已提交
459
  if (IS_SIGNED_NUMERIC_TYPE(pVariant->nType) || (pVariant->nType == TSDB_DATA_TYPE_BOOL)) {
460
    *result = pVariant->i;
461
  } else if (IS_UNSIGNED_NUMERIC_TYPE(pVariant->nType)) {
462
    *result = pVariant->u;
463
  } else if (IS_FLOAT_TYPE(pVariant->nType)) {
H
Haojun Liao 已提交
464
    *result = (int64_t) pVariant->d;
465
  } else if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
H
Haojun Liao 已提交
466
    SToken token = {.z = pVariant->pz, .n = pVariant->nLen};
467
    /*int32_t n = */tGetToken(pVariant->pz, &token.type);
468

469 470
    if (token.type == TK_NULL) {
      if (releaseVariantPtr) {
wafwerar's avatar
wafwerar 已提交
471
        taosMemoryFree(pVariant->pz);
472 473
        pVariant->nLen = 0;
      }
474

H
Haojun Liao 已提交
475
      setNull((char *)result, type, tDataTypes[type].bytes);
476 477
      return 0;
    }
478 479 480 481

    // decide if it is a valid number
    token.type = tGetNumericStringType(&token);
    if (token.type == TK_ILLEGAL) {
482 483
      return -1;
    }
484 485

    int64_t res = 0;
486 487
    int32_t t = tStrToInteger(token.z, token.type, token.n, &res, issigned);
    if (t != 0) {
488 489
      return -1;
    }
490 491

    if (releaseVariantPtr) {
wafwerar's avatar
wafwerar 已提交
492
      taosMemoryFree(pVariant->pz);
493 494 495 496
      pVariant->nLen = 0;
    }

    *result = res;
497 498
  } else if (pVariant->nType == TSDB_DATA_TYPE_NCHAR) {
    errno = 0;
wafwerar's avatar
wafwerar 已提交
499
    TdUcs4 *endPtr = NULL;
500
    
H
Haojun Liao 已提交
501
    SToken token = {0};
502
    token.n = tGetToken(pVariant->pz, &token.type);
503 504
    
    if (token.type == TK_MINUS || token.type == TK_PLUS) {
505
      token.n = tGetToken(pVariant->pz + token.n, &token.type);
506 507 508
    }
    
    if (token.type == TK_FLOAT) {
wafwerar's avatar
wafwerar 已提交
509
      double v = wcstod(pVariant->ucs4, &endPtr);
510
      if (releaseVariantPtr) {
wafwerar's avatar
wafwerar 已提交
511
        taosMemoryFree(pVariant->pz);
512 513 514 515 516 517 518 519 520 521
        pVariant->nLen = 0;
      }
      
      if ((errno == ERANGE && v == -1) || (isinf(v) || isnan(v))) {
        return -1;
      }
      
      *result = (int64_t)v;
    } else if (token.type == TK_NULL) {
      if (releaseVariantPtr) {
wafwerar's avatar
wafwerar 已提交
522
        taosMemoryFree(pVariant->pz);
523 524
        pVariant->nLen = 0;
      }
H
Haojun Liao 已提交
525
      setNull((char *)result, type, tDataTypes[type].bytes);
526 527
      return 0;
    } else {
wafwerar's avatar
wafwerar 已提交
528
      int64_t val = wcstoll(pVariant->ucs4, &endPtr, 10);
529
      if (releaseVariantPtr) {
wafwerar's avatar
wafwerar 已提交
530
        taosMemoryFree(pVariant->pz);
531 532 533 534 535 536 537 538 539 540
        pVariant->nLen = 0;
      }
      
      if (errno == ERANGE) {
        return -1;  // data overflow
      }
      
      *result = val;
    }
  }
541

W
wpan 已提交
542 543 544 545
  if (converted) {
    *converted = true;
  }

546
  bool code = false;
547 548

  uint64_t ui = 0;
549 550 551 552 553 554 555 556 557 558
  switch(type) {
    case TSDB_DATA_TYPE_TINYINT:
      code = IS_VALID_TINYINT(*result); break;
    case TSDB_DATA_TYPE_SMALLINT:
      code = IS_VALID_SMALLINT(*result); break;
    case TSDB_DATA_TYPE_INT:
      code = IS_VALID_INT(*result); break;
    case TSDB_DATA_TYPE_BIGINT:
      code = IS_VALID_BIGINT(*result); break;
    case TSDB_DATA_TYPE_UTINYINT:
559 560
      ui = *result;
      code = IS_VALID_UTINYINT(ui); break;
561
    case TSDB_DATA_TYPE_USMALLINT:
562 563
      ui = *result;
      code = IS_VALID_USMALLINT(ui); break;
564
    case TSDB_DATA_TYPE_UINT:
565 566
      ui = *result;
      code = IS_VALID_UINT(ui); break;
567
    case TSDB_DATA_TYPE_UBIGINT:
568 569
      ui = *result;
      code = IS_VALID_UBIGINT(ui); break;
570
  }
571

H
Haojun Liao 已提交
572

573
  return code? 0:-1;
H
Haojun Liao 已提交
574 575
#endif
  return 0;
576 577
}

H
Haojun Liao 已提交
578
static int32_t convertToBool(SVariant *pVariant, int64_t *pDest) {
579
  if (pVariant->nType == TSDB_DATA_TYPE_BOOL) {
580
    *pDest = pVariant->i;  // in order to be compatible to null of bool
581
  } else if (IS_NUMERIC_TYPE(pVariant->nType)) {
582
    *pDest = ((pVariant->i != 0) ? TSDB_TRUE : TSDB_FALSE);
583
  } else if (pVariant->nType == TSDB_DATA_TYPE_FLOAT || pVariant->nType == TSDB_DATA_TYPE_DOUBLE) {
H
Haojun Liao 已提交
584
    *pDest = ((pVariant->d != 0) ? TSDB_TRUE : TSDB_FALSE);
585 586 587 588 589
  } else if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
    int32_t ret = 0;
    if ((ret = convertToBoolImpl(pVariant->pz, pVariant->nLen)) < 0) {
      return ret;
    }
X
Xiaoyu Wang 已提交
590

591 592 593
    *pDest = ret;
  } else if (pVariant->nType == TSDB_DATA_TYPE_NCHAR) {
    int32_t ret = 0;
wafwerar's avatar
wafwerar 已提交
594
    if ((ret = wcsconvertToBoolImpl(pVariant->ucs4, pVariant->nLen)) < 0) {
595 596 597 598 599 600
      return ret;
    }
    *pDest = ret;
  } else if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
    *pDest = TSDB_DATA_BOOL_NULL;
  }
X
Xiaoyu Wang 已提交
601

602 603 604 605 606 607 608 609
  assert(*pDest == TSDB_TRUE || *pDest == TSDB_FALSE || *pDest == TSDB_DATA_BOOL_NULL);
  return 0;
}

/*
 * transfer data from variant serve as the implicit data conversion: from input sql string pVariant->nType
 * to column type defined in schema
 */
X
Xiaoyu Wang 已提交
610 611
int32_t tVariantDumpEx(SVariant *pVariant, char *payload, int16_t type, bool includeLengthPrefix, bool *converted,
                       char *extInfo) {
W
wpan 已提交
612 613 614
  if (converted) {
    *converted = false;
  }
X
Xiaoyu Wang 已提交
615

616
  if (pVariant == NULL || (pVariant->nType != 0 && !isValidDataType(pVariant->nType))) {
617 618
    return -1;
  }
619

620
  errno = 0;  // reset global error code
H
Haojun Liao 已提交
621
  int64_t result = 0;
622

623 624
  switch (type) {
    case TSDB_DATA_TYPE_BOOL: {
625
      if (convertToBool(pVariant, &result) < 0) {
626 627
        return -1;
      }
628 629

      *(int8_t *)payload = (int8_t)result;
630 631
      break;
    }
X
Xiaoyu Wang 已提交
632

633
    case TSDB_DATA_TYPE_TINYINT: {
W
wpan 已提交
634 635
      if (convertToInteger(pVariant, &result, type, true, false, converted) < 0) {
        SET_EXT_INFO(converted, result, INT8_MIN + 1, INT8_MAX, extInfo);
636 637
        return -1;
      }
X
Xiaoyu Wang 已提交
638
      *((int8_t *)payload) = (int8_t)result;
639 640 641 642
      break;
    }

    case TSDB_DATA_TYPE_UTINYINT: {
X
Xiaoyu Wang 已提交
643
      if (convertToInteger(pVariant, &result, type, false, false, converted) < 0) {
W
wpan 已提交
644
        SET_EXT_INFO(converted, result, 0, UINT8_MAX - 1, extInfo);
645 646
        return -1;
      }
X
Xiaoyu Wang 已提交
647
      *((uint8_t *)payload) = (uint8_t)result;
648 649
      break;
    }
X
Xiaoyu Wang 已提交
650

651
    case TSDB_DATA_TYPE_SMALLINT: {
W
wpan 已提交
652 653
      if (convertToInteger(pVariant, &result, type, true, false, converted) < 0) {
        SET_EXT_INFO(converted, result, INT16_MIN + 1, INT16_MAX, extInfo);
654 655 656 657 658
        return -1;
      }
      *((int16_t *)payload) = (int16_t)result;
      break;
    }
659 660

    case TSDB_DATA_TYPE_USMALLINT: {
W
wpan 已提交
661 662
      if (convertToInteger(pVariant, &result, type, false, false, converted) < 0) {
        SET_EXT_INFO(converted, result, 0, UINT16_MAX - 1, extInfo);
663 664 665 666 667
        return -1;
      }
      *((uint16_t *)payload) = (uint16_t)result;
      break;
    }
X
Xiaoyu Wang 已提交
668

669
    case TSDB_DATA_TYPE_INT: {
W
wpan 已提交
670 671
      if (convertToInteger(pVariant, &result, type, true, false, converted) < 0) {
        SET_EXT_INFO(converted, result, INT32_MIN + 1, INT32_MAX, extInfo);
672 673 674 675 676
        return -1;
      }
      *((int32_t *)payload) = (int32_t)result;
      break;
    }
677 678

    case TSDB_DATA_TYPE_UINT: {
W
wpan 已提交
679 680
      if (convertToInteger(pVariant, &result, type, false, false, converted) < 0) {
        SET_EXT_INFO(converted, result, 0, UINT32_MAX - 1, extInfo);
681 682 683 684 685
        return -1;
      }
      *((uint32_t *)payload) = (uint32_t)result;
      break;
    }
X
Xiaoyu Wang 已提交
686

687
    case TSDB_DATA_TYPE_BIGINT: {
W
wpan 已提交
688 689
      if (convertToInteger(pVariant, &result, type, true, false, converted) < 0) {
        SET_EXT_INFO(converted, (int64_t)result, INT64_MIN + 1, INT64_MAX, extInfo);
690 691 692 693 694
        return -1;
      }
      *((int64_t *)payload) = (int64_t)result;
      break;
    }
695 696

    case TSDB_DATA_TYPE_UBIGINT: {
W
wpan 已提交
697 698
      if (convertToInteger(pVariant, &result, type, false, false, converted) < 0) {
        SET_EXT_INFO(converted, (uint64_t)result, 0, UINT64_MAX - 1, extInfo);
699 700 701 702 703 704
        return -1;
      }
      *((uint64_t *)payload) = (uint64_t)result;
      break;
    }

705 706 707 708 709 710 711
    case TSDB_DATA_TYPE_FLOAT: {
      if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
        if (strncasecmp(TSDB_DATA_NULL_STR_L, pVariant->pz, pVariant->nLen) == 0 &&
            strlen(TSDB_DATA_NULL_STR_L) == pVariant->nLen) {
          *((int32_t *)payload) = TSDB_DATA_FLOAT_NULL;
          return 0;
        } else {
S
Shengliang Guan 已提交
712
          double  value = -1;
713
          int32_t ret = convertToDouble(pVariant->pz, pVariant->nLen, &value);
714 715 716 717
          if ((errno == ERANGE && (float)value == -1) || (ret != 0)) {
            return -1;
          }

W
wpan 已提交
718 719 720
          if (converted) {
            *converted = true;
          }
X
Xiaoyu Wang 已提交
721

W
wpan 已提交
722 723 724 725
          if (value > FLT_MAX || value < -FLT_MAX) {
            SET_EXT_INFO(converted, value, -FLT_MAX, FLT_MAX, extInfo);
            return -1;
          }
S
TD-1530  
Shengliang Guan 已提交
726
          SET_FLOAT_VAL(payload, value);
727
        }
X
Xiaoyu Wang 已提交
728 729
      } else if (pVariant->nType == TSDB_DATA_TYPE_BOOL || IS_SIGNED_NUMERIC_TYPE(pVariant->nType) ||
                 IS_UNSIGNED_NUMERIC_TYPE(pVariant->nType)) {
W
wpan 已提交
730 731 732
        if (converted) {
          *converted = true;
        }
X
Xiaoyu Wang 已提交
733 734

        if (pVariant->i > FLT_MAX || pVariant->i < -FLT_MAX) {
735
          SET_EXT_INFO(converted, pVariant->i, -FLT_MAX, FLT_MAX, extInfo);
W
wpan 已提交
736 737 738
          return -1;
        }

739
        SET_FLOAT_VAL(payload, pVariant->i);
740
      } else if (IS_FLOAT_TYPE(pVariant->nType)) {
W
wpan 已提交
741 742 743
        if (converted) {
          *converted = true;
        }
X
Xiaoyu Wang 已提交
744 745

        if (pVariant->d > FLT_MAX || pVariant->d < -FLT_MAX) {
H
Haojun Liao 已提交
746
          SET_EXT_INFO(converted, pVariant->d, -FLT_MAX, FLT_MAX, extInfo);
W
wpan 已提交
747 748
          return -1;
        }
X
Xiaoyu Wang 已提交
749

H
Haojun Liao 已提交
750
        SET_FLOAT_VAL(payload, pVariant->d);
751
      } else if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
752
        *((uint32_t *)payload) = TSDB_DATA_FLOAT_NULL;
753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775
        return 0;
      }

      float fv = GET_FLOAT_VAL(payload);
      if (isinf(fv) || isnan(fv) || fv > FLT_MAX || fv < -FLT_MAX) {
        return -1;
      }
      break;
    }
    case TSDB_DATA_TYPE_DOUBLE: {
      if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
        if (strncasecmp(TSDB_DATA_NULL_STR_L, pVariant->pz, pVariant->nLen) == 0 &&
            strlen(TSDB_DATA_NULL_STR_L) == pVariant->nLen) {
          *((int64_t *)payload) = TSDB_DATA_DOUBLE_NULL;
          return 0;
        } else {
          double  value = 0;
          int32_t ret;
          ret = convertToDouble(pVariant->pz, pVariant->nLen, &value);
          if ((errno == ERANGE && value == -1) || (ret != 0)) {
            return -1;
          }

S
TD-1530  
Shengliang Guan 已提交
776
          SET_DOUBLE_VAL(payload, value);
777
        }
X
Xiaoyu Wang 已提交
778 779
      } else if (pVariant->nType == TSDB_DATA_TYPE_BOOL || IS_SIGNED_NUMERIC_TYPE(pVariant->nType) ||
                 IS_UNSIGNED_NUMERIC_TYPE(pVariant->nType)) {
780
        SET_DOUBLE_VAL(payload, pVariant->i);
781
      } else if (IS_FLOAT_TYPE(pVariant->nType)) {
H
Haojun Liao 已提交
782
        SET_DOUBLE_VAL(payload, pVariant->d);
783 784 785 786 787 788
      } else if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
        *((int64_t *)payload) = TSDB_DATA_DOUBLE_NULL;
        return 0;
      }

      double dv = GET_DOUBLE_VAL(payload);
789
      if (errno == ERANGE || isinf(dv) || isnan(dv)) {
790 791
        return -1;
      }
792

793 794
      break;
    }
X
Xiaoyu Wang 已提交
795

796
    case TSDB_DATA_TYPE_BINARY: {
797 798
      if (!includeLengthPrefix) {
        if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
X
Xiaoyu Wang 已提交
799
          *(uint8_t *)payload = TSDB_DATA_BINARY_NULL;
800 801 802 803 804 805 806
        } else {
          if (pVariant->nType != TSDB_DATA_TYPE_BINARY) {
            toBinary(pVariant, &payload, &pVariant->nLen);
          } else {
            strncpy(payload, pVariant->pz, pVariant->nLen);
          }
        }
807
      } else {
808 809
        if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
          setVardataNull(payload, TSDB_DATA_TYPE_BINARY);
810
        } else {
811 812 813 814 815 816 817 818 819 820
          char *p = varDataVal(payload);

          if (pVariant->nType != TSDB_DATA_TYPE_BINARY) {
            toBinary(pVariant, &p, &pVariant->nLen);
          } else {
            strncpy(p, pVariant->pz, pVariant->nLen);
          }

          varDataSetLen(payload, pVariant->nLen);
          assert(p == varDataVal(payload));
821 822 823 824 825 826 827 828
        }
      }
      break;
    }
    case TSDB_DATA_TYPE_TIMESTAMP: {
      if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
        *((int64_t *)payload) = TSDB_DATA_BIGINT_NULL;
      } else {
829
        *((int64_t *)payload) = pVariant->i;
830 831 832 833
      }
      break;
    }
    case TSDB_DATA_TYPE_NCHAR: {
L
liu0x54 已提交
834
      int32_t newlen = 0;
835 836 837 838 839
      if (!includeLengthPrefix) {
        if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
          *(uint32_t *)payload = TSDB_DATA_NCHAR_NULL;
        } else {
          if (pVariant->nType != TSDB_DATA_TYPE_NCHAR) {
840 841 842
            if (toNchar(pVariant, &payload, &newlen) != 0) {
              return -1;
            }
843
          } else {
X
Xiaoyu Wang 已提交
844
            tasoUcs4Copy((TdUcs4 *)payload, pVariant->ucs4, pVariant->nLen);
845 846
          }
        }
847
      } else {
848 849
        if (pVariant->nType == TSDB_DATA_TYPE_NULL) {
          setVardataNull(payload, TSDB_DATA_TYPE_NCHAR);
850
        } else {
851 852 853
          char *p = varDataVal(payload);

          if (pVariant->nType != TSDB_DATA_TYPE_NCHAR) {
854 855 856
            if (toNchar(pVariant, &p, &newlen) != 0) {
              return -1;
            }
857
          } else {
wafwerar's avatar
wafwerar 已提交
858
            memcpy(p, pVariant->ucs4, pVariant->nLen);
L
liu0x54 已提交
859
            newlen = pVariant->nLen;
860 861
          }

L
liu0x54 已提交
862
          varDataSetLen(payload, newlen);  // the length may be changed after toNchar function called
863
          assert(p == varDataVal(payload));
864 865
        }
      }
X
Xiaoyu Wang 已提交
866

867 868 869
      break;
    }
  }
X
Xiaoyu Wang 已提交
870

871 872 873
  return 0;
}

H
Haojun Liao 已提交
874 875 876 877
/*
 * transfer data from variant serve as the implicit data conversion: from input sql string pVariant->nType
 * to column type defined in schema
 */
H
Haojun Liao 已提交
878
int32_t taosVariantDump(SVariant *pVariant, char *payload, int16_t type, bool includeLengthPrefix) {
H
Haojun Liao 已提交
879 880
  return tVariantDumpEx(pVariant, payload, type, includeLengthPrefix, NULL, NULL);
}
W
wpan 已提交
881

882 883 884 885 886 887
/*
 * In variant, bool/smallint/tinyint/int/bigint share the same attribution of
 * structure, also ignore the convert the type required
 *
 * It is actually the bigint/binary/bool/nchar type transfer
 */
888
int32_t taosVariantTypeSetType(SVariant *pVariant, char type) {
889 890 891
  if (pVariant == NULL || pVariant->nType == 0) {  // value is not set
    return 0;
  }
X
Xiaoyu Wang 已提交
892

893 894
  switch (type) {
    case TSDB_DATA_TYPE_BOOL: {  // bool
895
      if (convertToBool(pVariant, &pVariant->i) < 0) {
896 897
        return -1;
      }
X
Xiaoyu Wang 已提交
898

899 900 901 902 903 904 905
      pVariant->nType = type;
      break;
    }
    case TSDB_DATA_TYPE_INT:
    case TSDB_DATA_TYPE_BIGINT:
    case TSDB_DATA_TYPE_TINYINT:
    case TSDB_DATA_TYPE_SMALLINT: {
906
      convertToInteger(pVariant, &(pVariant->i), type, true, true, NULL);
907 908 909 910 911 912 913
      pVariant->nType = TSDB_DATA_TYPE_BIGINT;
      break;
    }
    case TSDB_DATA_TYPE_FLOAT:
    case TSDB_DATA_TYPE_DOUBLE: {
      if (pVariant->nType == TSDB_DATA_TYPE_BINARY) {
        errno = 0;
wafwerar's avatar
wafwerar 已提交
914
        double v = taosStr2Double(pVariant->pz, NULL);
915
        if ((errno == ERANGE && v == -1) || (isinf(v) || isnan(v))) {
wafwerar's avatar
wafwerar 已提交
916
          taosMemoryFree(pVariant->pz);
917 918
          return -1;
        }
X
Xiaoyu Wang 已提交
919

wafwerar's avatar
wafwerar 已提交
920
        taosMemoryFree(pVariant->pz);
H
Haojun Liao 已提交
921
        pVariant->d = v;
922 923
      } else if (pVariant->nType == TSDB_DATA_TYPE_NCHAR) {
        errno = 0;
wafwerar's avatar
wafwerar 已提交
924
        double v = wcstod(pVariant->ucs4, NULL);
925
        if ((errno == ERANGE && v == -1) || (isinf(v) || isnan(v))) {
wafwerar's avatar
wafwerar 已提交
926
          taosMemoryFree(pVariant->pz);
927 928
          return -1;
        }
X
Xiaoyu Wang 已提交
929

wafwerar's avatar
wafwerar 已提交
930
        taosMemoryFree(pVariant->pz);
H
Haojun Liao 已提交
931
        pVariant->d = v;
932
      } else if (pVariant->nType >= TSDB_DATA_TYPE_BOOL && pVariant->nType <= TSDB_DATA_TYPE_BIGINT) {
X
Xiaoyu Wang 已提交
933
        double tmp = (double)pVariant->i;
H
Haojun Liao 已提交
934
        pVariant->d = tmp;
935
      }
X
Xiaoyu Wang 已提交
936

937 938 939 940 941 942 943 944 945 946 947 948
      pVariant->nType = TSDB_DATA_TYPE_DOUBLE;
      break;
    }
    case TSDB_DATA_TYPE_BINARY: {
      if (pVariant->nType != TSDB_DATA_TYPE_BINARY) {
        toBinary(pVariant, &pVariant->pz, &pVariant->nLen);
      }
      pVariant->nType = type;
      break;
    }
    case TSDB_DATA_TYPE_NCHAR: {
      if (pVariant->nType != TSDB_DATA_TYPE_NCHAR) {
949
        if (toNchar(pVariant, &pVariant->pz, &pVariant->nLen) != 0) {
950 951
          return -1;
        }
952 953 954 955 956
      }
      pVariant->nType = type;
      break;
    }
  }
X
Xiaoyu Wang 已提交
957

958
  return 0;
959
}
D
dapan1121 已提交
960

X
Xiaoyu Wang 已提交
961
char *taosVariantGet(SVariant *pVar, int32_t type) {
D
dapan1121 已提交
962
  switch (type) {
G
Ganlin Zhao 已提交
963
    case TSDB_DATA_TYPE_BOOL:
D
dapan1121 已提交
964 965
    case TSDB_DATA_TYPE_TINYINT:
    case TSDB_DATA_TYPE_SMALLINT:
G
Ganlin Zhao 已提交
966
    case TSDB_DATA_TYPE_INT:
D
dapan1121 已提交
967 968 969
    case TSDB_DATA_TYPE_BIGINT:
    case TSDB_DATA_TYPE_TIMESTAMP:
      return (char *)&pVar->i;
G
Ganlin Zhao 已提交
970 971 972 973 974
    case TSDB_DATA_TYPE_UTINYINT:
    case TSDB_DATA_TYPE_USMALLINT:
    case TSDB_DATA_TYPE_UINT:
    case TSDB_DATA_TYPE_UBIGINT:
      return (char *)&pVar->u;
D
dapan1121 已提交
975 976 977 978 979 980 981
    case TSDB_DATA_TYPE_DOUBLE:
    case TSDB_DATA_TYPE_FLOAT:
      return (char *)&pVar->d;
    case TSDB_DATA_TYPE_BINARY:
      return (char *)pVar->pz;
    case TSDB_DATA_TYPE_NCHAR:
      return (char *)pVar->ucs4;
G
Ganlin Zhao 已提交
982
    default:
D
dapan1121 已提交
983 984 985 986 987
      return NULL;
  }

  return NULL;
}