Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
944363cd
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
提交
944363cd
编写于
12月 17, 2021
作者:
wmmhello
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
optimize code
上级
29fbe681
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
10 addition
and
14 deletion
+10
-14
src/client/src/tscSQLParser.c
src/client/src/tscSQLParser.c
+3
-10
src/client/src/tscUtil.c
src/client/src/tscUtil.c
+4
-2
src/tsdb/src/tsdbRead.c
src/tsdb/src/tsdbRead.c
+3
-2
未找到文件。
src/client/src/tscSQLParser.c
浏览文件 @
944363cd
...
@@ -143,6 +143,7 @@ static bool validateDebugFlag(int32_t v);
...
@@ -143,6 +143,7 @@ static bool validateDebugFlag(int32_t v);
static
int32_t
checkQueryRangeForFill
(
SSqlCmd
*
pCmd
,
SQueryInfo
*
pQueryInfo
);
static
int32_t
checkQueryRangeForFill
(
SSqlCmd
*
pCmd
,
SQueryInfo
*
pQueryInfo
);
static
int32_t
loadAllTableMeta
(
SSqlObj
*
pSql
,
struct
SSqlInfo
*
pInfo
);
static
int32_t
loadAllTableMeta
(
SSqlObj
*
pSql
,
struct
SSqlInfo
*
pInfo
);
static
tSqlExpr
*
extractExprForSTable
(
SSqlCmd
*
pCmd
,
tSqlExpr
**
pExpr
,
SQueryInfo
*
pQueryInfo
,
int32_t
tableIndex
);
static
tSqlExpr
*
extractExprForSTable
(
SSqlCmd
*
pCmd
,
tSqlExpr
**
pExpr
,
SQueryInfo
*
pQueryInfo
,
int32_t
tableIndex
);
static
void
convertWhereStringCharset
(
tSqlExpr
*
pRight
);
int
validateTableName
(
char
*
tblName
,
int
len
,
SStrToken
*
psTblToken
,
bool
*
dbIncluded
);
int
validateTableName
(
char
*
tblName
,
int
len
,
SStrToken
*
psTblToken
,
bool
*
dbIncluded
);
...
@@ -4968,15 +4969,7 @@ static int32_t validateJsonTagExpr(tSqlExpr* pExpr, char* msgBuf) {
...
@@ -4968,15 +4969,7 @@ static int32_t validateJsonTagExpr(tSqlExpr* pExpr, char* msgBuf) {
pRight
->
value
.
nType
=
TSDB_DATA_TYPE_NCHAR
;
pRight
->
value
.
nType
=
TSDB_DATA_TYPE_NCHAR
;
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
char
newData
[
TSDB_MAX_JSON_TAGS_LEN
]
=
{
0
};
convertWhereStringCharset
(
pRight
);
int
len
=
0
;
if
(
!
taosMbsToUcs4
(
pRight
->
value
.
pz
,
pRight
->
value
.
nLen
,
newData
,
TSDB_MAX_JSON_TAGS_LEN
,
&
len
)){
tscError
(
"json where condition mbsToUcs4 error"
);
}
pRight
->
value
.
pz
=
realloc
(
pRight
->
value
.
pz
,
len
);
memcpy
(
pRight
->
value
.
pz
,
newData
,
len
);
pRight
->
value
.
nLen
=
len
;
pRight
->
value
.
nType
=
TSDB_DATA_TYPE_NCHAR
;
}
}
}
}
...
@@ -5040,7 +5033,7 @@ int32_t handleNeOptr(tSqlExpr** rexpr, tSqlExpr* expr) {
...
@@ -5040,7 +5033,7 @@ int32_t handleNeOptr(tSqlExpr** rexpr, tSqlExpr* expr) {
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
static
void
convertWhereStringCharset
(
tSqlExpr
*
pRight
){
void
convertWhereStringCharset
(
tSqlExpr
*
pRight
){
if
(
pRight
->
value
.
nType
!=
TSDB_DATA_TYPE_BINARY
){
if
(
pRight
->
value
.
nType
!=
TSDB_DATA_TYPE_BINARY
){
return
;
return
;
}
}
...
...
src/client/src/tscUtil.c
浏览文件 @
944363cd
...
@@ -5509,18 +5509,20 @@ int parseJsontoTagData(char* json, SKVRowBuilder* kvRowBuilder, char* errMsg, in
...
@@ -5509,18 +5509,20 @@ int parseJsontoTagData(char* json, SKVRowBuilder* kvRowBuilder, char* errMsg, in
if
(
item
->
type
==
cJSON_String
){
// add json value format: type|data
if
(
item
->
type
==
cJSON_String
){
// add json value format: type|data
char
*
jsonValue
=
item
->
valuestring
;
char
*
jsonValue
=
item
->
valuestring
;
outLen
=
0
;
outLen
=
0
;
char
tagVal
[
TSDB_MAX_JSON_TAGS_LEN
]
=
{
0
}
;
char
*
tagVal
=
calloc
(
strlen
(
jsonValue
)
*
TSDB_NCHAR_SIZE
+
TSDB_NCHAR_SIZE
,
1
)
;
*
tagVal
=
jsonType2DbType
(
0
,
item
->
type
);
// type
*
tagVal
=
jsonType2DbType
(
0
,
item
->
type
);
// type
char
*
tagData
=
POINTER_SHIFT
(
tagVal
,
CHAR_BYTES
);
char
*
tagData
=
POINTER_SHIFT
(
tagVal
,
CHAR_BYTES
);
if
(
!
taosMbsToUcs4
(
jsonValue
,
strlen
(
jsonValue
),
varDataVal
(
tagData
),
if
(
!
taosMbsToUcs4
(
jsonValue
,
strlen
(
jsonValue
),
varDataVal
(
tagData
),
TSDB_MAX_JSON_TAGS_LEN
-
CHAR_BYTES
-
VARSTR_HEADE
R_SIZE
,
&
outLen
))
{
strlen
(
jsonValue
)
*
TSDB_NCHA
R_SIZE
,
&
outLen
))
{
tscError
(
"json string error:%s|%s"
,
strerror
(
errno
),
jsonValue
);
tscError
(
"json string error:%s|%s"
,
strerror
(
errno
),
jsonValue
);
retCode
=
tscSQLSyntaxErrMsg
(
errMsg
,
"serizelize json error"
,
NULL
);
retCode
=
tscSQLSyntaxErrMsg
(
errMsg
,
"serizelize json error"
,
NULL
);
free
(
tagVal
);
goto
end
;
goto
end
;
}
}
varDataSetLen
(
tagData
,
outLen
);
varDataSetLen
(
tagData
,
outLen
);
tdAddColToKVRow
(
kvRowBuilder
,
jsonIndex
++
,
TSDB_DATA_TYPE_NCHAR
,
tagVal
,
true
);
tdAddColToKVRow
(
kvRowBuilder
,
jsonIndex
++
,
TSDB_DATA_TYPE_NCHAR
,
tagVal
,
true
);
free
(
tagVal
);
}
else
if
(
item
->
type
==
cJSON_Number
){
}
else
if
(
item
->
type
==
cJSON_Number
){
char
tagVal
[
LONG_BYTES
+
CHAR_BYTES
]
=
{
0
};
char
tagVal
[
LONG_BYTES
+
CHAR_BYTES
]
=
{
0
};
*
tagVal
=
jsonType2DbType
(
item
->
valuedouble
,
item
->
type
);
// type
*
tagVal
=
jsonType2DbType
(
item
->
valuedouble
,
item
->
type
);
// type
...
...
src/tsdb/src/tsdbRead.c
浏览文件 @
944363cd
...
@@ -4231,7 +4231,6 @@ char* parseTagDatatoJson(void *p){
...
@@ -4231,7 +4231,6 @@ char* parseTagDatatoJson(void *p){
memset
(
tagJsonKey
,
0
,
sizeof
(
tagJsonKey
));
memset
(
tagJsonKey
,
0
,
sizeof
(
tagJsonKey
));
memcpy
(
tagJsonKey
,
varDataVal
(
val
),
varDataLen
(
val
));
memcpy
(
tagJsonKey
,
varDataVal
(
val
),
varDataLen
(
val
));
}
else
{
// json value
}
else
{
// json value
char
tagJsonValue
[
TSDB_MAX_JSON_TAGS_LEN
]
=
{
0
};
char
*
realData
=
POINTER_SHIFT
(
val
,
CHAR_BYTES
);
char
*
realData
=
POINTER_SHIFT
(
val
,
CHAR_BYTES
);
char
type
=
*
(
char
*
)
val
;
char
type
=
*
(
char
*
)
val
;
if
(
type
==
TSDB_DATA_TYPE_BINARY
)
{
if
(
type
==
TSDB_DATA_TYPE_BINARY
)
{
...
@@ -4244,14 +4243,16 @@ char* parseTagDatatoJson(void *p){
...
@@ -4244,14 +4243,16 @@ char* parseTagDatatoJson(void *p){
}
}
cJSON_AddItemToObject
(
json
,
tagJsonKey
,
value
);
cJSON_AddItemToObject
(
json
,
tagJsonKey
,
value
);
}
else
if
(
type
==
TSDB_DATA_TYPE_NCHAR
)
{
}
else
if
(
type
==
TSDB_DATA_TYPE_NCHAR
)
{
char
*
tagJsonValue
=
calloc
(
varDataLen
(
realData
),
1
);
int32_t
length
=
taosUcs4ToMbs
(
varDataVal
(
realData
),
varDataLen
(
realData
),
tagJsonValue
);
int32_t
length
=
taosUcs4ToMbs
(
varDataVal
(
realData
),
varDataLen
(
realData
),
tagJsonValue
);
if
(
length
<
0
)
{
if
(
length
<
0
)
{
tsdbError
(
"charset:%s to %s. val:%s convert json value failed."
,
DEFAULT_UNICODE_ENCODEC
,
tsCharset
,
tsdbError
(
"charset:%s to %s. val:%s convert json value failed."
,
DEFAULT_UNICODE_ENCODEC
,
tsCharset
,
(
char
*
)
val
);
(
char
*
)
val
);
free
(
tagJsonValue
);
goto
end
;
goto
end
;
}
}
cJSON
*
value
=
cJSON_CreateString
(
tagJsonValue
);
cJSON
*
value
=
cJSON_CreateString
(
tagJsonValue
);
free
(
tagJsonValue
);
if
(
value
==
NULL
)
if
(
value
==
NULL
)
{
{
goto
end
;
goto
end
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录