Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
097a2b92
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
097a2b92
编写于
12月 15, 2022
作者:
wmmhello
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
opti:modify parse json
上级
ac16bfc4
变更
7
显示空白变更内容
内联
并排
Showing
7 changed file
with
283 addition
and
944 deletion
+283
-944
source/client/inc/clientSml.h
source/client/inc/clientSml.h
+3
-3
source/client/src/clientSml.c
source/client/src/clientSml.c
+1
-2
source/client/src/clientSmlJson.c
source/client/src/clientSmlJson.c
+211
-481
source/client/src/clientSmlLine.c
source/client/src/clientSmlLine.c
+27
-27
source/client/src/clientSmlTelnet.c
source/client/src/clientSmlTelnet.c
+1
-1
source/client/test/smlTest.cpp
source/client/test/smlTest.cpp
+37
-146
utils/test/c/sml_test.c
utils/test/c/sml_test.c
+3
-284
未找到文件。
source/client/inc/clientSml.h
浏览文件 @
097a2b92
...
...
@@ -113,7 +113,7 @@ typedef struct {
int32_t
sTableNameLen
;
char
childTableName
[
TSDB_TABLE_NAME_LEN
];
uint64_t
uid
;
void
*
key
;
// for openTsdb
telnet
void
*
key
;
// for openTsdb
SArray
*
tags
;
...
...
@@ -177,7 +177,7 @@ typedef struct {
int32_t
lineNum
;
SSmlMsgBuf
msgBuf
;
cJSON
*
root
;
// for parse json
//
cJSON *root; // for parse json
SSmlLineInfo
*
lines
;
// element is SSmlLineInfo
//
...
...
@@ -216,7 +216,7 @@ SSmlSTableMeta* smlBuildSTableMeta(bool isDataFormat);
int32_t
smlSetCTableName
(
SSmlTableInfo
*
oneTable
);
STableMeta
*
smlGetMeta
(
SSmlHandle
*
info
,
const
void
*
measure
,
int32_t
measureLen
);
int32_t
is_same_child_table_telnet
(
const
void
*
a
,
const
void
*
b
);
int
32_t
is_same_child_table_json
(
const
void
*
a
,
const
void
*
b
);
int
64_t
smlParseOpenTsdbTime
(
SSmlHandle
*
info
,
const
char
*
data
,
int32_t
len
);
int32_t
smlClearForRerun
(
SSmlHandle
*
info
);
int32_t
smlParseInfluxString
(
SSmlHandle
*
info
,
char
*
sql
,
char
*
sqlEnd
,
SSmlLineInfo
*
elements
);
...
...
source/client/src/clientSml.c
浏览文件 @
097a2b92
...
...
@@ -1060,7 +1060,6 @@ static void smlDestroyInfo(SSmlHandle *info) {
taosMemoryFree
(
info
->
lines
);
}
cJSON_Delete
(
info
->
root
);
taosMemoryFreeClear
(
info
);
}
...
...
@@ -1125,7 +1124,7 @@ static int32_t smlParseLineBottom(SSmlHandle *info) {
}
else
if
(
info
->
protocol
==
TSDB_SML_TELNET_PROTOCOL
){
tinfo
=
(
SSmlTableInfo
*
)
nodeListGet
(
info
->
childTables
,
elements
,
POINTER_BYTES
,
is_same_child_table_telnet
);
}
else
{
tinfo
=
(
SSmlTableInfo
*
)
nodeListGet
(
info
->
childTables
,
elements
->
tags
,
POINTER_BYTES
,
is_same_child_table_json
);
tinfo
=
(
SSmlTableInfo
*
)
nodeListGet
(
info
->
childTables
,
elements
,
POINTER_BYTES
,
is_same_child_table_telnet
);
}
if
(
tinfo
==
NULL
){
...
...
source/client/src/clientSmlJson.c
浏览文件 @
097a2b92
...
...
@@ -19,353 +19,65 @@
#include <string.h>
#include "clientSml.h"
#define OTD_JSON_SUB_FIELDS_NUM 2
#define OTD_JSON_FIELDS_NUM 4
#define JSON_METERS_NAME "__JM"
int32_t
is_same_child_table_json
(
const
void
*
a
,
const
void
*
b
){
return
(
cJSON_Compare
((
const
cJSON
*
)
a
,
(
const
cJSON
*
)
b
,
true
))
?
0
:
1
;
}
static
inline
int32_t
smlParseMetricFromJSON
(
SSmlHandle
*
info
,
cJSON
*
metric
,
SSmlLineInfo
*
elements
)
{
elements
->
measureLen
=
strlen
(
metric
->
valuestring
);
if
(
IS_INVALID_TABLE_LEN
(
elements
->
measureLen
))
{
uError
(
"OTD:0x%"
PRIx64
" Metric lenght is 0 or large than 192"
,
info
->
id
);
return
TSDB_CODE_TSC_INVALID_TABLE_ID_LENGTH
;
}
elements
->
measure
=
metric
->
valuestring
;
return
TSDB_CODE_SUCCESS
;
}
static
int64_t
smlParseTSFromJSONObj
(
SSmlHandle
*
info
,
cJSON
*
root
,
int32_t
toPrecision
)
{
int32_t
size
=
cJSON_GetArraySize
(
root
);
if
(
unlikely
(
size
!=
OTD_JSON_SUB_FIELDS_NUM
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalidate json"
,
NULL
);
return
-
1
;
}
cJSON
*
value
=
cJSON_GetObjectItem
(
root
,
"value"
);
if
(
unlikely
(
!
cJSON_IsNumber
(
value
)))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalidate json"
,
NULL
);
return
-
1
;
}
cJSON
*
type
=
cJSON_GetObjectItem
(
root
,
"type"
);
if
(
unlikely
(
!
cJSON_IsString
(
type
)))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalidate json"
,
NULL
);
return
-
1
;
}
double
timeDouble
=
value
->
valuedouble
;
if
(
unlikely
(
smlDoubleToInt64OverFlow
(
timeDouble
)))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"timestamp is too large"
,
NULL
);
return
-
1
;
}
if
(
timeDouble
==
0
)
{
return
taosGetTimestampNs
()
/
smlFactorNS
[
toPrecision
];
}
if
(
timeDouble
<
0
)
{
return
timeDouble
;
}
int64_t
tsInt64
=
timeDouble
;
size_t
typeLen
=
strlen
(
type
->
valuestring
);
if
(
typeLen
==
1
&&
(
type
->
valuestring
[
0
]
==
's'
||
type
->
valuestring
[
0
]
==
'S'
))
{
// seconds
int8_t
fromPrecision
=
TSDB_TIME_PRECISION_SECONDS
;
if
(
smlFactorS
[
toPrecision
]
<
INT64_MAX
/
tsInt64
){
return
tsInt64
*
smlFactorS
[
toPrecision
];
}
return
-
1
;
}
else
if
(
typeLen
==
2
&&
(
type
->
valuestring
[
1
]
==
's'
||
type
->
valuestring
[
1
]
==
'S'
))
{
switch
(
type
->
valuestring
[
0
])
{
case
'm'
:
case
'M'
:
// milliseconds
return
convertTimePrecision
(
tsInt64
,
TSDB_TIME_PRECISION_MILLI
,
toPrecision
);
break
;
case
'u'
:
case
'U'
:
// microseconds
return
convertTimePrecision
(
tsInt64
,
TSDB_TIME_PRECISION_MICRO
,
toPrecision
);
break
;
case
'n'
:
case
'N'
:
return
convertTimePrecision
(
tsInt64
,
TSDB_TIME_PRECISION_NANO
,
toPrecision
);
break
;
default:
return
-
1
;
}
}
else
{
return
-
1
;
}
}
static
inline
uint8_t
smlGetTimestampLen
(
int64_t
num
)
{
uint8_t
len
=
0
;
while
((
num
/=
10
)
!=
0
)
{
len
++
;
}
len
++
;
return
len
;
}
static
int64_t
smlParseTSFromJSON
(
SSmlHandle
*
info
,
cJSON
*
timestamp
)
{
// Timestamp must be the first KV to parse
int32_t
toPrecision
=
info
->
currSTableMeta
?
info
->
currSTableMeta
->
tableInfo
.
precision
:
TSDB_TIME_PRECISION_NANO
;
if
(
cJSON_IsNumber
(
timestamp
))
{
// timestamp value 0 indicates current system time
double
timeDouble
=
timestamp
->
valuedouble
;
if
(
unlikely
(
smlDoubleToInt64OverFlow
(
timeDouble
)))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"timestamp is too large"
,
NULL
);
return
-
1
;
}
if
(
unlikely
(
timeDouble
<
0
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"timestamp is negative"
,
NULL
);
return
timeDouble
;
}
else
if
(
unlikely
(
timeDouble
==
0
))
{
return
taosGetTimestampNs
()
/
smlFactorNS
[
toPrecision
];
}
uint8_t
tsLen
=
smlGetTimestampLen
((
int64_t
)
timeDouble
);
int8_t
fromPrecision
=
smlGetTsTypeByLen
(
tsLen
);
if
(
unlikely
(
fromPrecision
==
-
1
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"timestamp precision can only be seconds(10 digits) or milli seconds(13 digits)"
,
NULL
);
return
-
1
;
}
int64_t
tsInt64
=
timeDouble
;
if
(
fromPrecision
==
TSDB_TIME_PRECISION_SECONDS
){
if
(
smlFactorS
[
toPrecision
]
<
INT64_MAX
/
tsInt64
){
return
tsInt64
*
smlFactorS
[
toPrecision
];
}
return
-
1
;
}
else
{
return
convertTimePrecision
(
timeDouble
,
fromPrecision
,
toPrecision
);
}
}
else
if
(
cJSON_IsObject
(
timestamp
))
{
return
smlParseTSFromJSONObj
(
info
,
timestamp
,
toPrecision
);
}
else
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalidate json"
,
NULL
);
return
-
1
;
}
}
static
int32_t
smlConvertJSONBool
(
SSmlKv
*
pVal
,
char
*
typeStr
,
cJSON
*
value
)
{
if
(
strcasecmp
(
typeStr
,
"bool"
)
!=
0
)
{
uError
(
"OTD:invalid type(%s) for JSON Bool"
,
typeStr
);
return
TSDB_CODE_TSC_INVALID_JSON_TYPE
;
}
pVal
->
type
=
TSDB_DATA_TYPE_BOOL
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
pVal
->
i
=
value
->
valueint
;
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
smlConvertJSONNumber
(
SSmlKv
*
pVal
,
char
*
typeStr
,
cJSON
*
value
)
{
// tinyint
if
(
strcasecmp
(
typeStr
,
"i8"
)
==
0
||
strcasecmp
(
typeStr
,
"tinyint"
)
==
0
)
{
if
(
!
IS_VALID_TINYINT
(
value
->
valuedouble
))
{
uError
(
"OTD:JSON value(%f) cannot fit in type(tinyint)"
,
value
->
valuedouble
);
return
TSDB_CODE_TSC_VALUE_OUT_OF_RANGE
;
}
pVal
->
type
=
TSDB_DATA_TYPE_TINYINT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
pVal
->
i
=
value
->
valuedouble
;
return
TSDB_CODE_SUCCESS
;
}
// smallint
if
(
strcasecmp
(
typeStr
,
"i16"
)
==
0
||
strcasecmp
(
typeStr
,
"smallint"
)
==
0
)
{
if
(
!
IS_VALID_SMALLINT
(
value
->
valuedouble
))
{
uError
(
"OTD:JSON value(%f) cannot fit in type(smallint)"
,
value
->
valuedouble
);
return
TSDB_CODE_TSC_VALUE_OUT_OF_RANGE
;
}
pVal
->
type
=
TSDB_DATA_TYPE_SMALLINT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
pVal
->
i
=
value
->
valuedouble
;
return
TSDB_CODE_SUCCESS
;
}
// int
if
(
strcasecmp
(
typeStr
,
"i32"
)
==
0
||
strcasecmp
(
typeStr
,
"int"
)
==
0
)
{
if
(
!
IS_VALID_INT
(
value
->
valuedouble
))
{
uError
(
"OTD:JSON value(%f) cannot fit in type(int)"
,
value
->
valuedouble
);
return
TSDB_CODE_TSC_VALUE_OUT_OF_RANGE
;
}
pVal
->
type
=
TSDB_DATA_TYPE_INT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
pVal
->
i
=
value
->
valuedouble
;
return
TSDB_CODE_SUCCESS
;
}
// bigint
if
(
strcasecmp
(
typeStr
,
"i64"
)
==
0
||
strcasecmp
(
typeStr
,
"bigint"
)
==
0
)
{
pVal
->
type
=
TSDB_DATA_TYPE_BIGINT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
if
(
value
->
valuedouble
>=
(
double
)
INT64_MAX
)
{
pVal
->
i
=
INT64_MAX
;
}
else
if
(
value
->
valuedouble
<=
(
double
)
INT64_MIN
)
{
pVal
->
i
=
INT64_MIN
;
}
else
{
pVal
->
i
=
value
->
valuedouble
;
}
return
TSDB_CODE_SUCCESS
;
}
// float
if
(
strcasecmp
(
typeStr
,
"f32"
)
==
0
||
strcasecmp
(
typeStr
,
"float"
)
==
0
)
{
if
(
!
IS_VALID_FLOAT
(
value
->
valuedouble
))
{
uError
(
"OTD:JSON value(%f) cannot fit in type(float)"
,
value
->
valuedouble
);
return
TSDB_CODE_TSC_VALUE_OUT_OF_RANGE
;
}
pVal
->
type
=
TSDB_DATA_TYPE_FLOAT
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
pVal
->
f
=
value
->
valuedouble
;
return
TSDB_CODE_SUCCESS
;
}
// double
if
(
strcasecmp
(
typeStr
,
"f64"
)
==
0
||
strcasecmp
(
typeStr
,
"double"
)
==
0
)
{
pVal
->
type
=
TSDB_DATA_TYPE_DOUBLE
;
pVal
->
length
=
(
int16_t
)
tDataTypes
[
pVal
->
type
].
bytes
;
pVal
->
d
=
value
->
valuedouble
;
return
TSDB_CODE_SUCCESS
;
}
// if reach here means type is unsupported
uError
(
"OTD:invalid type(%s) for JSON Number"
,
typeStr
);
return
TSDB_CODE_TSC_INVALID_JSON_TYPE
;
}
static
int32_t
smlConvertJSONString
(
SSmlKv
*
pVal
,
char
*
typeStr
,
cJSON
*
value
)
{
if
(
strcasecmp
(
typeStr
,
"binary"
)
==
0
)
{
pVal
->
type
=
TSDB_DATA_TYPE_BINARY
;
}
else
if
(
strcasecmp
(
typeStr
,
"nchar"
)
==
0
)
{
pVal
->
type
=
TSDB_DATA_TYPE_NCHAR
;
}
else
{
uError
(
"OTD:invalid type(%s) for JSON String"
,
typeStr
);
return
TSDB_CODE_TSC_INVALID_JSON_TYPE
;
}
pVal
->
length
=
(
int16_t
)
strlen
(
value
->
valuestring
);
if
(
pVal
->
type
==
TSDB_DATA_TYPE_BINARY
&&
pVal
->
length
>
TSDB_MAX_BINARY_LEN
-
VARSTR_HEADER_SIZE
)
{
return
TSDB_CODE_PAR_INVALID_VAR_COLUMN_LEN
;
}
if
(
pVal
->
type
==
TSDB_DATA_TYPE_NCHAR
&&
pVal
->
length
>
(
TSDB_MAX_NCHAR_LEN
-
VARSTR_HEADER_SIZE
)
/
TSDB_NCHAR_SIZE
)
{
return
TSDB_CODE_PAR_INVALID_VAR_COLUMN_LEN
;
}
pVal
->
value
=
value
->
valuestring
;
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
smlParseValueFromJSONObj
(
cJSON
*
root
,
SSmlKv
*
kv
)
{
int32_t
ret
=
TSDB_CODE_SUCCESS
;
int32_t
size
=
cJSON_GetArraySize
(
root
);
if
(
size
!=
OTD_JSON_SUB_FIELDS_NUM
)
{
return
TSDB_CODE_TSC_INVALID_JSON
;
}
cJSON
*
value
=
cJSON_GetObjectItem
(
root
,
"value"
);
if
(
value
==
NULL
)
{
return
TSDB_CODE_TSC_INVALID_JSON
;
}
cJSON
*
type
=
cJSON_GetObjectItem
(
root
,
"type"
);
if
(
!
cJSON_IsString
(
type
))
{
return
TSDB_CODE_TSC_INVALID_JSON
;
}
switch
(
value
->
type
)
{
case
cJSON_True
:
case
cJSON_False
:
{
ret
=
smlConvertJSONBool
(
kv
,
type
->
valuestring
,
value
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
{
return
ret
;
}
break
;
}
case
cJSON_Number
:
{
ret
=
smlConvertJSONNumber
(
kv
,
type
->
valuestring
,
value
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
{
return
ret
;
}
break
;
}
case
cJSON_String
:
{
ret
=
smlConvertJSONString
(
kv
,
type
->
valuestring
,
value
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
{
return
ret
;
#define JUMP_JSON_SPACE(start,end) \
while(start < end){\
if(unlikely(isspace(*start) == 0))\
break;\
else\
start++;\
}
static
SArray
*
smlJsonParseTags
(
char
*
start
,
char
*
end
){
SArray
*
tags
=
taosArrayInit
(
4
,
sizeof
(
SSmlKv
));
while
(
start
<
end
){
SSmlKv
kv
=
{
0
};
kv
.
type
=
TSDB_DATA_TYPE_NCHAR
;
bool
isInQuote
=
false
;
while
(
start
<
end
){
if
(
!
isInQuote
&&
*
start
==
'"'
){
start
++
;
kv
.
key
=
start
;
isInQuote
=
true
;
continue
;
}
if
(
isInQuote
&&
*
start
==
'"'
){
kv
.
keyLen
=
start
-
kv
.
key
;
start
++
;
break
;
}
default:
return
TSDB_CODE_TSC_INVALID_JSON_TYPE
;
start
++
;
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
smlParseValueFromJSON
(
cJSON
*
root
,
SSmlKv
*
kv
)
{
switch
(
root
->
type
)
{
case
cJSON_True
:
case
cJSON_False
:
{
kv
->
type
=
TSDB_DATA_TYPE_BOOL
;
kv
->
length
=
(
int16_t
)
tDataTypes
[
kv
->
type
].
bytes
;
kv
->
i
=
root
->
valueint
;
break
;
bool
hasColon
=
false
;
while
(
start
<
end
){
if
(
!
hasColon
&&
*
start
==
':'
){
start
++
;
hasColon
=
true
;
continue
;
}
case
cJSON_Number
:
{
kv
->
type
=
TSDB_DATA_TYPE_DOUBLE
;
kv
->
length
=
(
int16_t
)
tDataTypes
[
kv
->
type
].
bytes
;
kv
->
d
=
root
->
valuedouble
;
break
;
if
(
hasColon
&&
kv
.
value
==
NULL
&&
(
isspace
(
*
start
)
==
0
&&
*
start
!=
'"'
)){
kv
.
value
=
start
;
start
++
;
continue
;
}
case
cJSON_String
:
{
/* set default JSON type to binary/nchar according to
* user configured parameter tsDefaultJSONStrType
*/
char
*
tsDefaultJSONStrType
=
"nchar"
;
// todo
smlConvertJSONString
(
kv
,
tsDefaultJSONStrType
,
root
);
if
(
hasColon
&&
kv
.
value
!=
NULL
&&
(
*
start
==
'"'
||
*
start
==
','
||
*
start
==
'}'
)){
kv
.
length
=
start
-
kv
.
value
;
taosArrayPush
(
tags
,
&
kv
);
start
++
;
break
;
}
case
cJSON_Object
:
{
int32_t
ret
=
smlParseValueFromJSONObj
(
root
,
kv
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
{
uError
(
"OTD:Failed to parse value from JSON Obj"
);
return
ret
;
start
++
;
}
break
;
}
default:
return
TSDB_CODE_TSC_INVALID_JSON
;
}
return
TSDB_CODE_SUCCESS
;
return
tags
;
}
static
int32_t
smlParseTagsFromJSON
(
SSmlHandle
*
info
,
cJSON
*
tags
,
SSmlLineInfo
*
elements
)
{
static
int32_t
smlParseTagsFromJSON
(
SSmlHandle
*
info
,
SSmlLineInfo
*
elements
)
{
int32_t
ret
=
TSDB_CODE_SUCCESS
;
// add measure to tags to identify one child table
// cJSON *cMeasure = cJSON_AddStringToObject(tags, JSON_METERS_NAME, elements->measure);
// if(unlikely(cMeasure == NULL)){
// return TSDB_CODE_TSC_INVALID_JSON;
// }
elements
->
tags
=
(
char
*
)
tags
;
if
(
is_same_child_table_json
(
elements
->
tags
,
info
->
preLine
.
tags
)
==
0
){
// cJSON_DeleteItemFromObjectCaseSensitive(tags, JSON_METERS_NAME);
if
(
is_same_child_table_telnet
(
elements
,
&
info
->
preLine
)
==
0
){
return
TSDB_CODE_SUCCESS
;
}
// cJSON_DeleteItemFromObjectCaseSensitive(tags, JSON_METERS_NAME);
bool
isSameMeasure
=
IS_SAME_SUPER_TABLE
;
...
...
@@ -400,31 +112,16 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
taosArraySetSize
(
preLineKV
,
0
);
}
int32_t
tagNum
=
cJSON_GetArraySize
(
tags
);
SArray
*
tags
=
smlJsonParseTags
(
elements
->
tags
,
elements
->
tags
+
elements
->
tagsLen
);
int32_t
tagNum
=
taosArrayGetSize
(
tags
);
for
(
int32_t
i
=
0
;
i
<
tagNum
;
++
i
)
{
cJSON
*
tag
=
cJSON_GetArrayItem
(
tags
,
i
);
if
(
unlikely
(
tag
==
NULL
))
{
return
TSDB_CODE_TSC_INVALID_JSON
;
}
// if(unlikely(tag == cMeasure)) continue;
size_t
keyLen
=
strlen
(
tag
->
string
);
if
(
unlikely
(
IS_INVALID_COL_LEN
(
keyLen
)))
{
uError
(
"OTD:Tag key length is 0 or too large than 64"
);
return
TSDB_CODE_TSC_INVALID_COLUMN_LENGTH
;
}
// add kv to SSmlKv
SSmlKv
kv
=
{.
key
=
tag
->
string
,
.
keyLen
=
keyLen
};
// value
ret
=
smlParseValueFromJSON
(
tag
,
&
kv
);
if
(
unlikely
(
ret
!=
TSDB_CODE_SUCCESS
))
{
return
ret
;
}
SSmlKv
kv
=
*
(
SSmlKv
*
)
taosArrayGet
(
tags
,
i
);
if
(
info
->
dataFormat
){
if
(
unlikely
(
cnt
+
1
>
info
->
currSTableMeta
->
tableInfo
.
numOfTags
)){
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
taosArrayDestroy
(
tags
);
return
TSDB_CODE_SUCCESS
;
}
...
...
@@ -432,6 +129,7 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
if
(
unlikely
(
cnt
>=
taosArrayGetSize
(
preLineKV
)))
{
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
taosArrayDestroy
(
tags
);
return
TSDB_CODE_SUCCESS
;
}
SSmlKv
*
preKV
=
(
SSmlKv
*
)
taosArrayGet
(
preLineKV
,
cnt
);
...
...
@@ -447,6 +145,7 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
if
(
unlikely
(
!
IS_SAME_KEY
)){
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
taosArrayDestroy
(
tags
);
return
TSDB_CODE_SUCCESS
;
}
}
else
{
...
...
@@ -454,6 +153,7 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
if
(
unlikely
(
cnt
>=
taosArrayGetSize
(
superKV
)))
{
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
taosArrayDestroy
(
tags
);
return
TSDB_CODE_SUCCESS
;
}
SSmlKv
*
preKV
=
(
SSmlKv
*
)
taosArrayGet
(
superKV
,
cnt
);
...
...
@@ -467,6 +167,7 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
if
(
unlikely
(
!
IS_SAME_KEY
)){
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
taosArrayDestroy
(
tags
);
return
TSDB_CODE_SUCCESS
;
}
}
else
{
...
...
@@ -479,8 +180,9 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
}
cnt
++
;
}
taosArrayDestroy
(
tags
);
SSmlTableInfo
*
tinfo
=
(
SSmlTableInfo
*
)
nodeListGet
(
info
->
childTables
,
elements
->
tags
,
POINTER_BYTES
,
is_same_child_table_json
);
SSmlTableInfo
*
tinfo
=
(
SSmlTableInfo
*
)
nodeListGet
(
info
->
childTables
,
elements
,
POINTER_BYTES
,
is_same_child_table_telnet
);
if
(
unlikely
(
tinfo
==
NULL
))
{
tinfo
=
smlBuildTableInfo
(
1
,
elements
->
measure
,
elements
->
measureLen
);
if
(
unlikely
(
!
tinfo
))
{
...
...
@@ -498,65 +200,152 @@ static int32_t smlParseTagsFromJSON(SSmlHandle *info, cJSON *tags, SSmlLineInfo
}
}
nodeListSet
(
&
info
->
childTables
,
tags
,
POINTER_BYTES
,
tinfo
,
is_same_child_table_json
);
SSmlLineInfo
*
key
=
(
SSmlLineInfo
*
)
taosMemoryMalloc
(
sizeof
(
SSmlLineInfo
));
*
key
=
*
elements
;
tinfo
->
key
=
key
;
nodeListSet
(
&
info
->
childTables
,
key
,
POINTER_BYTES
,
tinfo
,
is_same_child_table_telnet
);
}
if
(
info
->
dataFormat
)
info
->
currTableDataCtx
=
tinfo
->
tableDataCtx
;
return
ret
;
}
const
char
*
jsonName
[
OTD_JSON_FIELDS_NUM
]
=
{
"metric"
,
"timestamp"
,
"value"
,
"tags"
};
static
int32_t
smlGetJsonElements
(
cJSON
*
root
,
cJSON
***
marks
){
cJSON
*
child
=
root
->
child
;
static
char
*
smlJsonGetObj
(
char
*
payload
){
int
leftBracketCnt
=
0
;
while
(
*
payload
)
{
if
(
*
payload
==
'{'
)
{
leftBracketCnt
++
;
payload
++
;
continue
;
}
if
(
*
payload
==
'}'
)
{
leftBracketCnt
--
;
payload
++
;
if
(
leftBracketCnt
==
0
)
{
return
payload
;
}
else
if
(
leftBracketCnt
<
0
)
{
return
NULL
;
}
continue
;
}
payload
++
;
}
return
NULL
;
}
for
(
int
i
=
0
;
i
<
OTD_JSON_FIELDS_NUM
;
++
i
)
{
while
(
child
!=
NULL
)
{
if
(
strcasecmp
(
child
->
string
,
jsonName
[
i
])
==
0
){
*
marks
[
i
]
=
child
;
static
void
smlJsonParseObj
(
char
*
start
,
char
*
end
,
SSmlLineInfo
*
element
){
while
(
start
<
end
){
if
(
start
[
0
]
==
'"'
&&
start
[
1
]
==
'm'
&&
start
[
2
]
==
'e'
&&
start
[
3
]
==
't'
&&
start
[
4
]
==
'r'
&&
start
[
5
]
==
'i'
&&
start
[
6
]
==
'c'
&&
start
[
7
]
==
'"'
){
start
+=
8
;
bool
isInQuote
=
false
;
while
(
start
<
end
){
if
(
!
isInQuote
&&
*
start
==
'"'
){
start
++
;
element
->
measure
=
start
;
isInQuote
=
true
;
continue
;
}
if
(
isInQuote
&&
*
start
==
'"'
){
element
->
measureLen
=
start
-
element
->
measure
;
start
++
;
break
;
}
child
=
child
->
next
;
start
++
;
}
if
(
*
marks
[
i
]
==
NULL
){
uError
(
"smlGetJsonElements error, not find mark:%s"
,
jsonName
[
i
]);
return
-
1
;
}
else
if
(
start
[
0
]
==
'"'
&&
start
[
1
]
==
't'
&&
start
[
2
]
==
'i'
&&
start
[
3
]
==
'm'
&&
start
[
4
]
==
'e'
&&
start
[
5
]
==
's'
&&
start
[
6
]
==
't'
&&
start
[
7
]
==
'a'
&&
start
[
8
]
==
'm'
&&
start
[
9
]
==
'p'
&&
start
[
10
]
==
'"'
){
start
+=
11
;
bool
hasColon
=
false
;
while
(
start
<
end
){
if
(
!
hasColon
&&
*
start
==
':'
){
start
++
;
JUMP_JSON_SPACE
(
start
,
end
)
element
->
timestamp
=
start
;
hasColon
=
true
;
continue
;
}
if
(
hasColon
&&
(
*
start
==
','
||
*
start
==
'}'
||
isspace
(
*
start
)
!=
0
)){
element
->
timestampLen
=
start
-
element
->
timestamp
;
start
++
;
break
;
}
return
TSDB_CODE_SUCCESS
;
}
start
++
;
}
}
else
if
(
start
[
0
]
==
'"'
&&
start
[
1
]
==
'v'
&&
start
[
2
]
==
'a'
&&
start
[
3
]
==
'l'
&&
start
[
4
]
==
'u'
&&
start
[
5
]
==
'e'
&&
start
[
6
]
==
'"'
){
static
int32_t
smlParseJSONString
(
SSmlHandle
*
info
,
cJSON
*
root
,
SSmlLineInfo
*
elements
)
{
int32_t
ret
=
TSDB_CODE_SUCCESS
;
start
+=
7
;
cJSON
*
metricJson
=
NULL
;
cJSON
*
tsJson
=
NULL
;
cJSON
*
valueJson
=
NULL
;
cJSON
*
tagsJson
=
NULL
;
bool
hasColon
=
false
;
while
(
start
<
end
){
if
(
!
hasColon
&&
*
start
==
':'
){
start
++
;
JUMP_JSON_SPACE
(
start
,
end
)
element
->
cols
=
start
;
hasColon
=
true
;
continue
;
}
if
(
hasColon
&&
(
*
start
==
','
||
*
start
==
'}'
||
isspace
(
*
start
)
!=
0
)){
element
->
colsLen
=
start
-
element
->
cols
;
start
++
;
break
;
}
start
++
;
}
}
else
if
(
start
[
0
]
==
'"'
&&
start
[
1
]
==
't'
&&
start
[
2
]
==
'a'
&&
start
[
3
]
==
'g'
&&
start
[
4
]
==
's'
&&
start
[
5
]
==
'"'
){
start
+=
6
;
cJSON
**
marks
[
OTD_JSON_FIELDS_NUM
]
=
{
&
metricJson
,
&
tsJson
,
&
valueJson
,
&
tagsJson
};
ret
=
smlGetJsonElements
(
root
,
marks
);
if
(
unlikely
(
ret
!=
TSDB_CODE_SUCCESS
))
{
return
ret
;
while
(
start
<
end
){
if
(
*
start
==
':'
){
start
++
;
JUMP_JSON_SPACE
(
start
,
end
)
element
->
tags
=
start
;
element
->
tagsLen
=
smlJsonGetObj
(
start
)
-
start
;
break
;
}
start
++
;
}
}
else
{
start
++
;
}
}
}
// Parse metric
ret
=
smlParseMetricFromJSON
(
info
,
metricJson
,
elements
);
if
(
unlikely
(
ret
!=
TSDB_CODE_SUCCESS
))
{
uError
(
"OTD:0x%"
PRIx64
" Unable to parse metric from JSON payload"
,
info
->
id
);
return
ret
;
static
int32_t
smlParseJSONString
(
SSmlHandle
*
info
,
char
*
start
,
char
*
end
,
SSmlLineInfo
*
elements
)
{
int32_t
ret
=
TSDB_CODE_SUCCESS
;
smlJsonParseObj
(
start
,
end
,
elements
);
if
(
unlikely
(
elements
->
measure
==
NULL
||
elements
->
measureLen
==
0
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalid measure data"
,
start
);
return
TSDB_CODE_SML_INVALID_DATA
;
}
if
(
unlikely
(
elements
->
tags
==
NULL
||
elements
->
tagsLen
==
0
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalid tags data"
,
start
);
return
TSDB_CODE_SML_INVALID_DATA
;
}
if
(
unlikely
(
elements
->
cols
==
NULL
||
elements
->
colsLen
==
0
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalid cols data"
,
start
);
return
TSDB_CODE_SML_INVALID_DATA
;
}
if
(
unlikely
(
elements
->
timestamp
==
NULL
||
elements
->
timestampLen
==
0
))
{
smlBuildInvalidDataMsg
(
&
info
->
msgBuf
,
"invalid timestamp data"
,
start
);
return
TSDB_CODE_SML_INVALID_DATA
;
}
// Parse metric value
SSmlKv
kv
=
{.
key
=
VALUE
,
.
keyLen
=
VALUE_LEN
};
ret
=
smlParseValueFromJSON
(
valueJson
,
&
kv
);
if
(
unlikely
(
ret
))
{
uError
(
"OTD:0x%"
PRIx64
" Unable to parse metric value from JSON payload"
,
info
->
id
);
return
ret
;
SSmlKv
kv
=
{.
key
=
VALUE
,
.
keyLen
=
VALUE_LEN
,
.
value
=
elements
->
cols
,
.
length
=
(
size_t
)
elements
->
colsLen
};
if
(
smlParseNumber
(
&
kv
,
&
info
->
msgBuf
))
{
kv
.
length
=
(
int16_t
)
tDataTypes
[
kv
.
type
].
bytes
;
}
else
{
return
TSDB_CODE_TSC_INVALID_VALUE
;
}
// Parse tags
ret
=
smlParseTagsFromJSON
(
info
,
tagsJson
,
elements
);
ret
=
smlParseTagsFromJSON
(
info
,
elements
);
if
(
unlikely
(
ret
))
{
uError
(
"OTD:0x%"
PRIx64
" Unable to parse tags from JSON payload"
,
info
->
id
);
return
ret
;
...
...
@@ -568,7 +357,7 @@ static int32_t smlParseJSONString(SSmlHandle *info, cJSON *root, SSmlLineInfo *e
// Parse timestamp
// notice!!! put ts back to tag to ensure get meta->precision
int64_t
ts
=
smlParse
TSFromJSON
(
info
,
tsJso
n
);
int64_t
ts
=
smlParse
OpenTsdbTime
(
info
,
elements
->
timestamp
,
elements
->
timestampLe
n
);
if
(
unlikely
(
ts
<
0
))
{
uError
(
"OTD:0x%"
PRIx64
" Unable to parse timestamp from JSON payload"
,
info
->
id
);
return
TSDB_CODE_INVALID_TIMESTAMP
;
...
...
@@ -599,99 +388,39 @@ static int32_t smlParseJSONString(SSmlHandle *info, cJSON *root, SSmlLineInfo *e
return
TSDB_CODE_SUCCESS
;
}
int32_t
smlParseJSON
(
SSmlHandle
*
info
,
char
*
payload
)
{
int32_t
payloadNum
=
0
;
int32_t
ret
=
TSDB_CODE_SUCCESS
;
if
(
unlikely
(
payload
==
NULL
))
{
uError
(
"SML:0x%"
PRIx64
" empty JSON Payload"
,
info
->
id
);
return
TSDB_CODE_TSC_INVALID_JSON
;
}
info
->
root
=
cJSON_Parse
(
payload
);
if
(
unlikely
(
info
->
root
==
NULL
))
{
uError
(
"SML:0x%"
PRIx64
" parse json failed:%s"
,
info
->
id
,
payload
);
return
TSDB_CODE_TSC_INVALID_JSON
;
}
//#define JUMP_TO_QUOTE(sql) \
// while (sql){ \
// if (unlikely(isspace(*(sql))) != 0) \
// (sql)++; \
// else \
// break; \
// }
//
// multiple data points must be sent in JSON array
if
(
cJSON_IsArray
(
info
->
root
))
{
payloadNum
=
cJSON_GetArraySize
(
info
->
root
);
}
else
if
(
cJSON_IsObject
(
info
->
root
))
{
payloadNum
=
1
;
}
else
{
uError
(
"SML:0x%"
PRIx64
" Invalid JSON Payload"
,
info
->
id
);
return
TSDB_CODE_TSC_INVALID_JSON
;
}
cJSON
*
head
=
(
payloadNum
==
1
&&
cJSON_IsObject
(
info
->
root
))
?
info
->
root
:
info
->
root
->
child
;
int32_t
smlParseJSON
(
SSmlHandle
*
info
,
char
*
payload
)
{
int32_t
payloadNum
=
1
<<
15
;
int32_t
ret
=
TSDB_CODE_SUCCESS
;
int
cnt
=
0
;
cJSON
*
dataPoint
=
head
;
while
(
dataPoint
)
{
char
*
dataPointStart
=
payload
;
char
*
dataPointEnd
=
NULL
;
while
(
1
)
{
dataPointEnd
=
smlJsonGetObj
(
dataPointStart
);
if
(
dataPointEnd
==
NULL
)
break
;
if
(
info
->
dataFormat
)
{
SSmlLineInfo
element
=
{
0
};
ret
=
smlParseJSONString
(
info
,
dataPoint
,
&
element
);
ret
=
smlParseJSONString
(
info
,
dataPoint
Start
,
dataPointEnd
,
&
element
);
}
else
{
ret
=
smlParseJSONString
(
info
,
dataPoint
,
info
->
lines
+
cnt
);
if
(
cnt
>=
payloadNum
){
payloadNum
=
payloadNum
<<
1
;
void
*
tmp
=
taosMemoryRealloc
(
info
->
lines
,
payloadNum
*
sizeof
(
SSmlLineInfo
));
if
(
tmp
!=
NULL
){
info
->
lines
=
(
SSmlLineInfo
*
)
tmp
;
}
if
(
unlikely
(
ret
!=
TSDB_CODE_SUCCESS
))
{
uError
(
"SML:0x%"
PRIx64
" Invalid JSON Payload"
,
info
->
id
);
return
ret
;
}
if
(
unlikely
(
info
->
reRun
)){
cnt
=
0
;
dataPoint
=
head
;
info
->
lineNum
=
payloadNum
;
ret
=
smlClearForRerun
(
info
);
if
(
ret
!=
TSDB_CODE_SUCCESS
){
return
ret
;
}
continue
;
}
cnt
++
;
dataPoint
=
dataPoint
->
next
;
}
return
TSDB_CODE_SUCCESS
;
}
int32_t
smlParseJSONOld
(
SSmlHandle
*
info
,
char
*
payload
)
{
int32_t
payloadNum
=
0
;
int32_t
ret
=
TSDB_CODE_SUCCESS
;
if
(
unlikely
(
payload
==
NULL
))
{
uError
(
"SML:0x%"
PRIx64
" empty JSON Payload"
,
info
->
id
);
return
TSDB_CODE_TSC_INVALID_JSON
;
}
info
->
root
=
cJSON_Parse
(
payload
);
if
(
unlikely
(
info
->
root
==
NULL
))
{
uError
(
"SML:0x%"
PRIx64
" parse json failed:%s"
,
info
->
id
,
payload
);
return
TSDB_CODE_TSC_INVALID_JSON
;
}
// multiple data points must be sent in JSON array
if
(
cJSON_IsArray
(
info
->
root
))
{
payloadNum
=
cJSON_GetArraySize
(
info
->
root
);
}
else
if
(
cJSON_IsObject
(
info
->
root
))
{
payloadNum
=
1
;
}
else
{
uError
(
"SML:0x%"
PRIx64
" Invalid JSON Payload"
,
info
->
id
);
return
TSDB_CODE_TSC_INVALID_JSON
;
}
cJSON
*
head
=
(
payloadNum
==
1
&&
cJSON_IsObject
(
info
->
root
))
?
info
->
root
:
info
->
root
->
child
;
int
cnt
=
0
;
cJSON
*
dataPoint
=
head
;
while
(
dataPoint
)
{
if
(
info
->
dataFormat
)
{
SSmlLineInfo
element
=
{
0
};
ret
=
smlParseJSONString
(
info
,
dataPoint
,
&
element
);
}
else
{
ret
=
smlParseJSONString
(
info
,
dataPoint
,
info
->
lines
+
cnt
);
ret
=
smlParseJSONString
(
info
,
dataPointStart
,
dataPointEnd
,
info
->
lines
+
cnt
);
}
if
(
unlikely
(
ret
!=
TSDB_CODE_SUCCESS
))
{
uError
(
"SML:0x%"
PRIx64
" Invalid JSON Payload"
,
info
->
id
);
...
...
@@ -700,7 +429,7 @@ int32_t smlParseJSONOld(SSmlHandle *info, char *payload) {
if
(
unlikely
(
info
->
reRun
)){
cnt
=
0
;
dataPoint
=
he
ad
;
dataPoint
Start
=
paylo
ad
;
info
->
lineNum
=
payloadNum
;
ret
=
smlClearForRerun
(
info
);
if
(
ret
!=
TSDB_CODE_SUCCESS
){
...
...
@@ -709,8 +438,9 @@ int32_t smlParseJSONOld(SSmlHandle *info, char *payload) {
continue
;
}
cnt
++
;
dataPoint
=
dataPoint
->
next
;
dataPoint
Start
=
dataPointEnd
;
}
info
->
lineNum
=
cnt
;
return
TSDB_CODE_SUCCESS
;
}
source/client/src/clientSmlLine.c
浏览文件 @
097a2b92
...
...
@@ -456,7 +456,7 @@ static int32_t smlParseColKv(SSmlHandle *info, char **sql, char *sqlEnd,
bool
isInQuote
=
false
;
while
(
*
sql
<
sqlEnd
)
{
// parse value
if
(
IS_QUOTE
(
*
sql
))
{
if
(
unlikely
(
IS_QUOTE
(
*
sql
)
))
{
isInQuote
=
!
isInQuote
;
(
*
sql
)
++
;
continue
;
...
...
@@ -513,32 +513,32 @@ static int32_t smlParseColKv(SSmlHandle *info, char **sql, char *sqlEnd,
}
if
(
isSameMeasure
){
if
(
cnt
>=
taosArrayGetSize
(
preLineKV
))
{
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
return
TSDB_CODE_SUCCESS
;
}
SSmlKv
*
preKV
=
(
SSmlKv
*
)
taosArrayGet
(
preLineKV
,
cnt
);
if
(
kv
.
type
!=
preKV
->
type
){
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
return
TSDB_CODE_SUCCESS
;
}
if
(
unlikely
(
IS_VAR_DATA_TYPE
(
kv
.
type
)
&&
kv
.
length
>
preKV
->
length
)){
preKV
->
length
=
kv
.
length
;
SSmlSTableMeta
*
tableMeta
=
(
SSmlSTableMeta
*
)
nodeListGet
(
info
->
superTables
,
currElement
->
measure
,
currElement
->
measureLen
,
NULL
);
ASSERT
(
tableMeta
!=
NULL
);
SSmlKv
*
oldKV
=
(
SSmlKv
*
)
taosArrayGet
(
tableMeta
->
cols
,
cnt
);
oldKV
->
length
=
kv
.
length
;
info
->
needModifySchema
=
true
;
}
if
(
unlikely
(
!
IS_SAME_KEY
)){
info
->
dataFormat
=
false
;
info
->
reRun
=
true
;
return
TSDB_CODE_SUCCESS
;
}
//
if(cnt >= taosArrayGetSize(preLineKV)) {
//
info->dataFormat = false;
//
info->reRun = true;
//
return TSDB_CODE_SUCCESS;
//
}
//
SSmlKv *preKV = (SSmlKv *)taosArrayGet(preLineKV, cnt);
//
if(kv.type != preKV->type){
//
info->dataFormat = false;
//
info->reRun = true;
//
return TSDB_CODE_SUCCESS;
//
}
//
//
if(unlikely(IS_VAR_DATA_TYPE(kv.type) && kv.length > preKV->length)){
//
preKV->length = kv.length;
//
SSmlSTableMeta *tableMeta = (SSmlSTableMeta *)nodeListGet(info->superTables, currElement->measure, currElement->measureLen, NULL);
//
ASSERT(tableMeta != NULL);
//
//
SSmlKv *oldKV = (SSmlKv *)taosArrayGet(tableMeta->cols, cnt);
//
oldKV->length = kv.length;
//
info->needModifySchema = true;
//
}
//
if(unlikely(!IS_SAME_KEY)){
//
info->dataFormat = false;
//
info->reRun = true;
//
return TSDB_CODE_SUCCESS;
//
}
}
else
{
if
(
isSuperKVInit
){
if
(
unlikely
(
cnt
>=
taosArrayGetSize
(
superKV
)))
{
...
...
source/client/src/clientSmlTelnet.c
浏览文件 @
097a2b92
...
...
@@ -27,7 +27,7 @@ int32_t is_same_child_table_telnet(const void *a, const void *b){
&&
((
t1
->
tagsLen
==
t2
->
tagsLen
)
&&
memcmp
(
t1
->
tags
,
t2
->
tags
,
t1
->
tagsLen
)
==
0
))
?
0
:
1
;
}
static
int64_t
smlParseOpenTsdbTime
(
SSmlHandle
*
info
,
const
char
*
data
,
int32_t
len
)
{
int64_t
smlParseOpenTsdbTime
(
SSmlHandle
*
info
,
const
char
*
data
,
int32_t
len
)
{
uint8_t
toPrecision
=
info
->
currSTableMeta
?
info
->
currSTableMeta
->
tableInfo
.
precision
:
TSDB_TIME_PRECISION_NANO
;
if
(
unlikely
(
!
data
))
{
...
...
source/client/test/smlTest.cpp
浏览文件 @
097a2b92
...
...
@@ -414,28 +414,28 @@ TEST(testCase, smlParseCols_Test) {
smlDestroyInfo
(
info
);
}
TEST
(
testCase
,
smlGetTimestampLen_Test
)
{
uint8_t
len
=
smlGetTimestampLen
(
0
);
ASSERT_EQ
(
len
,
1
);
len
=
smlGetTimestampLen
(
1
);
ASSERT_EQ
(
len
,
1
);
len
=
smlGetTimestampLen
(
10
);
ASSERT_EQ
(
len
,
2
);
len
=
smlGetTimestampLen
(
390
);
ASSERT_EQ
(
len
,
3
);
len
=
smlGetTimestampLen
(
-
1
);
ASSERT_EQ
(
len
,
1
);
len
=
smlGetTimestampLen
(
-
10
);
ASSERT_EQ
(
len
,
2
);
len
=
smlGetTimestampLen
(
-
390
);
ASSERT_EQ
(
len
,
3
);
}
//
TEST(testCase, smlGetTimestampLen_Test) {
//
uint8_t len = smlGetTimestampLen(0);
//
ASSERT_EQ(len, 1);
//
//
len = smlGetTimestampLen(1);
//
ASSERT_EQ(len, 1);
//
//
len = smlGetTimestampLen(10);
//
ASSERT_EQ(len, 2);
//
//
len = smlGetTimestampLen(390);
//
ASSERT_EQ(len, 3);
//
//
len = smlGetTimestampLen(-1);
//
ASSERT_EQ(len, 1);
//
//
len = smlGetTimestampLen(-10);
//
ASSERT_EQ(len, 2);
//
//
len = smlGetTimestampLen(-390);
//
ASSERT_EQ(len, 3);
//
}
TEST
(
testCase
,
smlParseNumber_Test
)
{
SSmlKv
kv
=
{
0
};
...
...
@@ -487,139 +487,32 @@ TEST(testCase, smlParseTelnetLine_error_Test) {
smlDestroyInfo
(
info
);
}
TEST
(
testCase
,
smlParseTelnetLine_
json_error
_Test
)
{
TEST
(
testCase
,
smlParseTelnetLine_
diff_json_type2
_Test
)
{
SSmlHandle
*
info
=
smlBuildSmlInfo
(
NULL
);
info
->
protocol
=
TSDB_SML_JSON_PROTOCOL
;
info
->
dataFormat
=
false
;
ASSERT_NE
(
info
,
nullptr
);
const
char
*
sql
[]
=
{
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 13468464009999333322222223,
\n
"
"
\"
value
\"
: 18,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
host
\"
:
\"
web01
\"
,
\n
"
"
\"
dc
\"
:
\"
lga
\"\n
"
" }
\n
"
" },
\n
"
"]"
,
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 1346846400i,
\n
"
"
\"
value
\"
: 18,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
host
\"
:
\"
web01
\"
,
\n
"
"
\"
dc
\"
:
\"
lga
\"\n
"
" }
\n
"
" },
\n
"
"]"
,
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 1346846400,
\n
"
"
\"
value
\"
: 18,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
groupid
\"
: {
\n
"
"
\"
value
\"
: 2,
\n
"
"
\"
type
\"
:
\"
nchar
\"\n
"
" },
\n
"
"
\"
location
\"
: {
\n
"
"
\"
value
\"
:
\"
北京
\"
,
\n
"
"
\"
type
\"
:
\"
binary
\"\n
"
" },
\n
"
"
\"
id
\"
:
\"
d1001
\"\n
"
" }
\n
"
" },
\n
"
"]"
,
"[{
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\"
timestamp
\"
: 1346846400,
\"
value
\"
: 18,
\"
tags
\"
: {
\"
host
\"
:
\"
lga
\"
}},{
\"
metric
\"
:
\"
sys.sdfa
\"
,
\"
timestamp
\"
: 1346846400,
\"
value
\"
:
\"
18
\"
,
\"
tags
\"
: {
\"
host
\"
: 8932}},]"
,
};
int
ret
=
TSDB_CODE_SUCCESS
;
for
(
int
i
=
0
;
i
<
sizeof
(
sql
)
/
sizeof
(
sql
[
0
]);
i
++
)
{
SSmlLineInfo
elements
=
{
0
};
ret
=
smlParseTelnetString
(
info
,
(
char
*
)
sql
[
i
],
(
char
*
)(
sql
[
i
]
+
strlen
(
sql
[
i
])),
&
elements
);
ASSERT_NE
(
ret
,
0
);
}
smlDestroyInfo
(
info
);
}
TEST
(
testCase
,
smlParseTelnetLine_diff_json_type1_Test
)
{
SSmlHandle
*
info
=
smlBuildSmlInfo
(
NULL
);
info
->
protocol
=
TSDB_SML_JSON_PROTOCOL
;
info
->
dataFormat
=
false
;
ASSERT_NE
(
info
,
nullptr
);
char
*
dataPointStart
=
(
char
*
)
sql
[
i
];
char
*
dataPointEnd
=
NULL
;
while
(
1
)
{
dataPointEnd
=
smlJsonGetObj
(
dataPointStart
);
if
(
dataPointEnd
==
NULL
)
break
;
const
char
*
sql
[]
=
{
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 1346846400,
\n
"
"
\"
value
\"
: 18,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
host
\"
:
\"
lga
\"\n
"
" }
\n
"
" },
\n
"
"]"
,
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 1346846400,
\n
"
"
\"
value
\"
: 18,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
host
\"
: 8
\n
"
" }
\n
"
" },
\n
"
"]"
,
};
int
ret
=
TSDB_CODE_SUCCESS
;
for
(
int
i
=
0
;
i
<
sizeof
(
sql
)
/
sizeof
(
sql
[
0
]);
i
++
)
{
SSmlLineInfo
elements
=
{
0
};
ret
=
smlParseTelnetString
(
info
,
(
char
*
)
sql
[
i
],
(
char
*
)(
sql
[
i
]
+
strlen
(
sql
[
i
])),
&
elements
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
break
;
}
ASSERT_NE
(
ret
,
0
);
smlDestroyInfo
(
info
);
}
smlJsonParseObj
(
dataPointStart
,
dataPointEnd
,
&
elements
);
TEST
(
testCase
,
smlParseTelnetLine_diff_json_type2_Test
)
{
SSmlHandle
*
info
=
smlBuildSmlInfo
(
NULL
);
info
->
protocol
=
TSDB_SML_JSON_PROTOCOL
;
info
->
dataFormat
=
false
;
ASSERT_NE
(
info
,
nullptr
);
SArray
*
tags
=
smlJsonParseTags
(
elements
.
tags
,
elements
.
tags
+
elements
.
tagsLen
);
size_t
num
=
taosArrayGetSize
(
tags
);
ASSERT_EQ
(
num
,
1
);
const
char
*
sql
[]
=
{
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 1346846400,
\n
"
"
\"
value
\"
: 18,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
host
\"
:
\"
lga
\"\n
"
" }
\n
"
" },
\n
"
"]"
,
"[
\n
"
" {
\n
"
"
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\n
"
"
\"
timestamp
\"
: 1346846400,
\n
"
"
\"
value
\"
:
\"
18
\"
,
\n
"
"
\"
tags
\"
: {
\n
"
"
\"
host
\"
:
\"
fff
\"\n
"
" }
\n
"
" },
\n
"
"]"
,
};
int
ret
=
TSDB_CODE_SUCCESS
;
for
(
int
i
=
0
;
i
<
sizeof
(
sql
)
/
sizeof
(
sql
[
0
]);
i
++
)
{
SSmlLineInfo
elements
=
{
0
};
ret
=
smlParseTelnetString
(
info
,
(
char
*
)
sql
[
i
],
(
char
*
)(
sql
[
i
]
+
strlen
(
sql
[
i
])),
&
elements
);
if
(
ret
!=
TSDB_CODE_SUCCESS
)
break
;
taosArrayDestroy
(
tags
);
dataPointStart
=
dataPointEnd
;
}
}
ASSERT_NE
(
ret
,
0
);
smlDestroyInfo
(
info
);
}
...
...
@@ -647,6 +540,4 @@ TEST(testCase, smlParseNumber_performance_Test) {
printf
(
"smlParseNumberOld:%s cost:%"
PRId64
,
str
[
i
],
taosGetTimestampUs
()
-
t2
);
printf
(
"
\n\n
"
);
}
}
\ No newline at end of file
utils/test/c/sml_test.c
浏览文件 @
097a2b92
...
...
@@ -156,28 +156,7 @@ int smlProcess_json3_Test() {
taos_free_result
(
pRes
);
const
char
*
sql
[]
=
{
"{
\"
metric
\"
:
\"
meter_current1
\"
,
\"
timestamp
\"
:{
\"
value
\"
:1662344042,
\"
type
\"
:
\"
s
\"
},
\"
value
\"
:{
\"
value
\"
:10.3,
\"
type
\"
:
\"
i64
\"
},
\"
tags
\"
:{
\"
t1
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
bigint
\"
},
\"
t2
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
int
\"
},
\"
t3
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
i16
\"
},
\"
t4
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
i8
\"
},
\"
t5
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
f32
\"
},
\"
t6
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
double
\"
},
\"
t7
\"
:{
\"
value
\"
:
\"
8323
\"
,
\"
type
\"
:
\"
binary
\"
},
\"
t8
\"
:{
\"
value
\"
:
\"
北京
\"
,
\"
type
\"
:
\"
nchar
\"
},
\"
t9
\"
:{
\"
value
\"
:true,
\"
type
\"
:
\"
bool
\"
},
\"
id
\"
:
\"
d1001
\"
}}"
};
pRes
=
taos_schemaless_insert
(
taos
,
(
char
**
)
sql
,
sizeof
(
sql
)
/
sizeof
(
sql
[
0
]),
TSDB_SML_JSON_PROTOCOL
,
TSDB_SML_TIMESTAMP_NANO_SECONDS
);
printf
(
"%s result:%s
\n
"
,
__FUNCTION__
,
taos_errstr
(
pRes
));
int
code
=
taos_errno
(
pRes
);
taos_free_result
(
pRes
);
taos_close
(
taos
);
return
code
;
}
int
smlProcess_json4_Test
()
{
TAOS
*
taos
=
taos_connect
(
"localhost"
,
"root"
,
"taosdata"
,
NULL
,
0
);
TAOS_RES
*
pRes
=
taos_query
(
taos
,
"create database if not exists sml_db schemaless 1"
);
taos_free_result
(
pRes
);
pRes
=
taos_query
(
taos
,
"use sml_db"
);
taos_free_result
(
pRes
);
const
char
*
sql
[]
=
{
"{
\"
metric
\"
:
\"
meter_current2
\"
,
\"
timestamp
\"
:{
\"
value
\"
:1662344042000,
\"
type
\"
:
\"
ms
\"
},
\"
value
\"
:
\"
ni
\"
,
\"
tags
\"
:{
\"
t1
\"
:{
\"
value
\"
:20,
\"
type
\"
:
\"
i64
\"
},
\"
t2
\"
:{
\"
value
\"
:25,
\"
type
\"
:
\"
i32
\"
},
\"
t3
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
smallint
\"
},
\"
t4
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
tinyint
\"
},
\"
t5
\"
:{
\"
value
\"
:2,
\"
type
\"
:
\"
float
\"
},
\"
t6
\"
:{
\"
value
\"
:0.2,
\"
type
\"
:
\"
f64
\"
},
\"
t7
\"
:
\"
nsj
\"
,
\"
t8
\"
:{
\"
value
\"
:
\"
北京
\"
,
\"
type
\"
:
\"
nchar
\"
},
\"
t9
\"
:false,
\"
id
\"
:
\"
d1001
\"
}}"
"[{
\"
metric
\"
:
\"
sys.cpu.nice
\"
,
\"
timestamp
\"
:0,
\"
value
\"
:
\"
18
\"
,
\"
tags
\"
:{
\"
host
\"
:
\"
web01
\"
,
\"
id
\"
:
\"
t1
\"
,
\"
dc
\"
:
\"
lga
\"
}}]"
};
pRes
=
taos_schemaless_insert
(
taos
,
(
char
**
)
sql
,
sizeof
(
sql
)
/
sizeof
(
sql
[
0
]),
TSDB_SML_JSON_PROTOCOL
,
TSDB_SML_TIMESTAMP_NANO_SECONDS
);
...
...
@@ -686,52 +665,6 @@ int sml_oom_Test() {
return
code
;
}
int
sml_16368_Test
()
{
TAOS
*
taos
=
taos_connect
(
"localhost"
,
"root"
,
"taosdata"
,
NULL
,
0
);
TAOS_RES
*
pRes
=
taos_query
(
taos
,
"create database if not exists sml_db schemaless 1"
);
taos_free_result
(
pRes
);
pRes
=
taos_query
(
taos
,
"use sml_db"
);
taos_free_result
(
pRes
);
const
char
*
sql
[]
=
{
"[{
\"
metric
\"
:
\"
st123456
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833639000,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: 1, "
"
\"
tags
\"
: {
\"
t1
\"
: 3,
\"
t2
\"
: {
\"
value
\"
: 4,
\"
type
\"
:
\"
double
\"
},
\"
t3
\"
: {
\"
value
\"
:
\"
t3
\"
,
\"
type
\"
: "
"
\"
binary
\"
}}},"
"{
\"
metric
\"
:
\"
st123456
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833739000,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: 2, "
"
\"
tags
\"
: {
\"
t1
\"
: {
\"
value
\"
: 4,
\"
type
\"
:
\"
double
\"
},
\"
t3
\"
: {
\"
value
\"
:
\"
t4
\"
,
\"
type
\"
:
\"
binary
\"
}, "
"
\"
t2
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
},
\"
t4
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
}}},"
"{
\"
metric
\"
:
\"
stb_name
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833639100,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: 3, "
"
\"
tags
\"
: {
\"
t2
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
},
\"
t3
\"
: {
\"
value
\"
:
\"
ste
\"
,
\"
type
\"
:
\"
nchar
\"
}}},"
"{
\"
metric
\"
:
\"
stf567890
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833639200,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: 4, "
"
\"
tags
\"
: {
\"
t1
\"
: {
\"
value
\"
: 4,
\"
type
\"
:
\"
bigint
\"
},
\"
t3
\"
: {
\"
value
\"
:
\"
t4
\"
,
\"
type
\"
:
\"
binary
\"
}, "
"
\"
t2
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
},
\"
t4
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
}}},"
"{
\"
metric
\"
:
\"
st123456
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833639300,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: "
"{
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
},
\"
tags
\"
: {
\"
t1
\"
: {
\"
value
\"
: 4,
\"
type
\"
:
\"
double
\"
},
\"
t2
\"
: 5.0, "
"
\"
t3
\"
: {
\"
value
\"
:
\"
t4
\"
,
\"
type
\"
:
\"
binary
\"
}}},"
"{
\"
metric
\"
:
\"
stb_name
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833639400,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: "
"{
\"
value
\"
: 6,
\"
type
\"
:
\"
double
\"
},
\"
tags
\"
: {
\"
t2
\"
: 5.0,
\"
t3
\"
: {
\"
value
\"
:
\"
ste2
\"
,
\"
type
\"
: "
"
\"
nchar
\"
}}},"
"{
\"
metric
\"
:
\"
stb_name
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006834639400,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: "
"{
\"
value
\"
: 7,
\"
type
\"
:
\"
double
\"
},
\"
tags
\"
: {
\"
t2
\"
: {
\"
value
\"
: 5.0,
\"
type
\"
:
\"
double
\"
},
\"
t3
\"
: "
"{
\"
value
\"
:
\"
ste2
\"
,
\"
type
\"
:
\"
nchar
\"
}}},"
"{
\"
metric
\"
:
\"
st123456
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833839006,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: "
"{
\"
value
\"
: 8,
\"
type
\"
:
\"
double
\"
},
\"
tags
\"
: {
\"
t1
\"
: {
\"
value
\"
: 4,
\"
type
\"
:
\"
double
\"
},
\"
t3
\"
: "
"{
\"
value
\"
:
\"
t4
\"
,
\"
type
\"
:
\"
binary
\"
},
\"
t2
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
},
\"
t4
\"
: {
\"
value
\"
: 5, "
"
\"
type
\"
:
\"
double
\"
}}},"
"{
\"
metric
\"
:
\"
st123456
\"
,
\"
timestamp
\"
: {
\"
value
\"
: 1626006833939007,
\"
type
\"
:
\"
us
\"
},
\"
value
\"
: "
"{
\"
value
\"
: 9,
\"
type
\"
:
\"
double
\"
},
\"
tags
\"
: {
\"
t1
\"
: 4,
\"
t3
\"
: {
\"
value
\"
:
\"
t4
\"
,
\"
type
\"
:
\"
binary
\"
}, "
"
\"
t2
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
},
\"
t4
\"
: {
\"
value
\"
: 5,
\"
type
\"
:
\"
double
\"
}}}]"
};
pRes
=
taos_schemaless_insert
(
taos
,
(
char
**
)
sql
,
0
,
TSDB_SML_JSON_PROTOCOL
,
TSDB_SML_TIMESTAMP_MICRO_SECONDS
);
printf
(
"%s result:%s
\n
"
,
__FUNCTION__
,
taos_errstr
(
pRes
));
int
code
=
taos_errno
(
pRes
);
taos_free_result
(
pRes
);
taos_close
(
taos
);
return
code
;
}
int
sml_dup_time_Test
()
{
TAOS
*
taos
=
taos_connect
(
"localhost"
,
"root"
,
"taosdata"
,
NULL
,
0
);
...
...
@@ -771,214 +704,6 @@ int sml_dup_time_Test() {
return
code
;
}
int
sml_16960_Test
()
{
TAOS
*
taos
=
taos_connect
(
"localhost"
,
"root"
,
"taosdata"
,
NULL
,
0
);
TAOS_RES
*
pRes
=
taos_query
(
taos
,
"create database if not exists sml_db schemaless 1"
);
taos_free_result
(
pRes
);
pRes
=
taos_query
(
taos
,
"use sml_db"
);
taos_free_result
(
pRes
);
const
char
*
sql
[]
=
{
"["
"{"
"
\"
timestamp
\"
:"
""
"{
\"
value
\"
: 1664418955000,
\"
type
\"
:
\"
ms
\"
}"
","
"
\"
value
\"
:"
""
"{
\"
value
\"
: 830525384,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
tags
\"
: {"
"
\"
id
\"
:
\"
stb00_0
\"
,"
"
\"
t0
\"
:"
""
"{
\"
value
\"
: 83972721,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t1
\"
:"
""
"{
\"
value
\"
: 539147525,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t2
\"
:"
""
"{
\"
value
\"
: 618258572,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t3
\"
:"
""
"{
\"
value
\"
: -10536201,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t4
\"
:"
""
"{
\"
value
\"
: 349227409,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t5
\"
:"
""
"{
\"
value
\"
: 249347042,
\"
type
\"
:
\"
int
\"
}"
"},"
"
\"
metric
\"
:
\"
stb0
\"
"
"},"
"{"
"
\"
timestamp
\"
:"
""
"{
\"
value
\"
: 1664418955001,
\"
type
\"
:
\"
ms
\"
}"
","
"
\"
value
\"
:"
""
"{
\"
value
\"
: -588348364,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
tags
\"
: {"
"
\"
id
\"
:
\"
stb00_0
\"
,"
"
\"
t0
\"
:"
""
"{
\"
value
\"
: 83972721,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t1
\"
:"
""
"{
\"
value
\"
: 539147525,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t2
\"
:"
""
"{
\"
value
\"
: 618258572,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t3
\"
:"
""
"{
\"
value
\"
: -10536201,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t4
\"
:"
""
"{
\"
value
\"
: 349227409,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t5
\"
:"
""
"{
\"
value
\"
: 249347042,
\"
type
\"
:
\"
int
\"
}"
"},"
"
\"
metric
\"
:
\"
stb0
\"
"
"},"
"{"
"
\"
timestamp
\"
:"
""
"{
\"
value
\"
: 1664418955002,
\"
type
\"
:
\"
ms
\"
}"
","
"
\"
value
\"
:"
""
"{
\"
value
\"
: -370310823,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
tags
\"
: {"
"
\"
id
\"
:
\"
stb00_0
\"
,"
"
\"
t0
\"
:"
""
"{
\"
value
\"
: 83972721,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t1
\"
:"
""
"{
\"
value
\"
: 539147525,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t2
\"
:"
""
"{
\"
value
\"
: 618258572,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t3
\"
:"
""
"{
\"
value
\"
: -10536201,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t4
\"
:"
""
"{
\"
value
\"
: 349227409,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t5
\"
:"
""
"{
\"
value
\"
: 249347042,
\"
type
\"
:
\"
int
\"
}"
"},"
"
\"
metric
\"
:
\"
stb0
\"
"
"},"
"{"
"
\"
timestamp
\"
:"
""
"{
\"
value
\"
: 1664418955003,
\"
type
\"
:
\"
ms
\"
}"
","
"
\"
value
\"
:"
""
"{
\"
value
\"
: -811250191,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
tags
\"
: {"
"
\"
id
\"
:
\"
stb00_0
\"
,"
"
\"
t0
\"
:"
""
"{
\"
value
\"
: 83972721,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t1
\"
:"
""
"{
\"
value
\"
: 539147525,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t2
\"
:"
""
"{
\"
value
\"
: 618258572,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t3
\"
:"
""
"{
\"
value
\"
: -10536201,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t4
\"
:"
""
"{
\"
value
\"
: 349227409,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t5
\"
:"
""
"{
\"
value
\"
: 249347042,
\"
type
\"
:
\"
int
\"
}"
"},"
"
\"
metric
\"
:
\"
stb0
\"
"
"},"
"{"
"
\"
timestamp
\"
:"
""
"{
\"
value
\"
: 1664418955004,
\"
type
\"
:
\"
ms
\"
}"
","
"
\"
value
\"
:"
""
"{
\"
value
\"
: -330340558,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
tags
\"
: {"
"
\"
id
\"
:
\"
stb00_0
\"
,"
"
\"
t0
\"
:"
""
"{
\"
value
\"
: 83972721,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t1
\"
:"
""
"{
\"
value
\"
: 539147525,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t2
\"
:"
""
"{
\"
value
\"
: 618258572,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t3
\"
:"
""
"{
\"
value
\"
: -10536201,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t4
\"
:"
""
"{
\"
value
\"
: 349227409,
\"
type
\"
:
\"
int
\"
}"
","
"
\"
t5
\"
:"
""
"{
\"
value
\"
: 249347042,
\"
type
\"
:
\"
int
\"
}"
"},"
"
\"
metric
\"
:
\"
stb0
\"
"
"}"
"]"
};
pRes
=
taos_schemaless_insert
(
taos
,
(
char
**
)
sql
,
sizeof
(
sql
)
/
sizeof
(
sql
[
0
]),
TSDB_SML_JSON_PROTOCOL
,
TSDB_SML_TIMESTAMP_MILLI_SECONDS
);
printf
(
"%s result:%s
\n
"
,
__FUNCTION__
,
taos_errstr
(
pRes
));
int
code
=
taos_errno
(
pRes
);
taos_free_result
(
pRes
);
taos_close
(
taos
);
return
code
;
}
int
sml_add_tag_col_Test
()
{
TAOS
*
taos
=
taos_connect
(
"localhost"
,
"root"
,
"taosdata"
,
NULL
,
0
);
...
...
@@ -1211,11 +936,9 @@ int main(int argc, char *argv[]) {
ret
=
smlProcess_json1_Test
();
ASSERT
(
!
ret
);
ret
=
smlProcess_json2_Test
();
ASSERT
(
!
ret
);
ASSERT
(
ret
);
ret
=
smlProcess_json3_Test
();
ASSERT
(
!
ret
);
ret
=
smlProcess_json4_Test
();
ASSERT
(
!
ret
);
ASSERT
(
ret
);
ret
=
sml_TD15662_Test
();
ASSERT
(
!
ret
);
ret
=
sml_TD15742_Test
();
...
...
@@ -1224,12 +947,8 @@ int main(int argc, char *argv[]) {
ASSERT
(
!
ret
);
ret
=
sml_oom_Test
();
ASSERT
(
!
ret
);
ret
=
sml_16368_Test
();
ASSERT
(
!
ret
);
ret
=
sml_dup_time_Test
();
ASSERT
(
!
ret
);
ret
=
sml_16960_Test
();
ASSERT
(
!
ret
);
ret
=
sml_add_tag_col_Test
();
ASSERT
(
!
ret
);
ret
=
smlProcess_18784_Test
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录