Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
0e49e115
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
提交
0e49e115
编写于
10月 18, 2021
作者:
wmmhello
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
TD-6129<feature> support null true false for json tag
上级
9aeeab9e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
12 deletion
+17
-12
src/query/src/qFilter.c
src/query/src/qFilter.c
+17
-12
未找到文件。
src/query/src/qFilter.c
浏览文件 @
0e49e115
...
...
@@ -1154,14 +1154,13 @@ _return:
return
code
;
}
int32_t
filterAddGroupUnitFromNode
(
SFilterInfo
*
info
,
tExprNode
*
tree
,
SArray
*
group
)
{
tExprNode
*
pLeft
=
tree
->
_node
.
pLeft
;
if
(
pLeft
->
nodeType
==
TSQL_NODE_EXPR
&&
pLeft
->
_node
.
optr
==
TSDB_RELATION_ARROW
){
// json tag -> operation
static
int32_t
filterDealJson
(
SFilterInfo
*
info
,
tExprNode
*
tree
,
tExprNode
**
pLeft
)
{
if
((
*
pLeft
)
->
nodeType
==
TSQL_NODE_EXPR
&&
(
*
pLeft
)
->
_node
.
optr
==
TSDB_RELATION_ARROW
){
// json tag -> operation
assert
(
info
->
pTable
!=
NULL
);
SSchema
*
schema
=
pLeft
->
_node
.
pLeft
->
pSchema
;
if
(
pLeft
->
_node
.
pRight
->
pVal
->
nLen
>
TSDB_MAX_JSON_KEY_LEN
)
return
TSDB_CODE_TSC_INVALID_COLUMN_LENGTH
;
SSchema
*
schema
=
(
*
pLeft
)
->
_node
.
pLeft
->
pSchema
;
if
(
(
*
pLeft
)
->
_node
.
pRight
->
pVal
->
nLen
>
TSDB_MAX_JSON_KEY_LEN
)
return
TSDB_CODE_TSC_INVALID_COLUMN_LENGTH
;
char
keyMd5
[
TSDB_MAX_JSON_KEY_MD5_LEN
]
=
{
0
};
jsonKeyMd5
(
pLeft
->
_node
.
pRight
->
pVal
->
pz
,
pLeft
->
_node
.
pRight
->
pVal
->
nLen
,
keyMd5
);
jsonKeyMd5
(
(
*
pLeft
)
->
_node
.
pRight
->
pVal
->
pz
,
(
*
pLeft
)
->
_node
.
pRight
->
pVal
->
nLen
,
keyMd5
);
memcpy
(
schema
->
name
,
keyMd5
,
TSDB_MAX_JSON_KEY_MD5_LEN
);
void
*
data
=
getJsonTagValue
(
info
->
pTable
,
schema
->
name
,
TSDB_MAX_JSON_KEY_MD5_LEN
,
&
schema
->
colId
);
...
...
@@ -1169,10 +1168,10 @@ int32_t filterAddGroupUnitFromNode(SFilterInfo *info, tExprNode* tree, SArray *g
schema
->
type
=
*
(
char
*
)
data
;
// if exist json tag-> operation get type so that can set data if (tree->_node.optr == TSDB_RELATION_IN_IN) the next and set value in filterInitValFieldData
assert
(
schema
->
type
>
TSDB_DATA_TYPE_NULL
&&
schema
->
type
<
TSDB_DATA_TYPE_JSON
);
}
pLeft
=
pLeft
->
_node
.
pLeft
;
// -> operation use left as input
(
*
pLeft
)
=
(
*
pLeft
)
->
_node
.
pLeft
;
// -> operation use left as input
if
(
IS_VAR_DATA_TYPE
(
tree
->
_node
.
pRight
->
pVal
->
nType
))
{
schema
=
pLeft
->
pSchema
;
if
(
tree
->
_node
.
pRight
->
nodeType
==
TSQL_NODE_VALUE
&&
IS_VAR_DATA_TYPE
(
tree
->
_node
.
pRight
->
pVal
->
nType
))
{
schema
=
(
*
pLeft
)
->
pSchema
;
if
(
!
IS_VAR_DATA_TYPE
(
schema
->
type
))
{
char
*
v
=
strndup
(
tree
->
_node
.
pRight
->
pVal
->
pz
,
tree
->
_node
.
pRight
->
pVal
->
nLen
);
uint32_t
type
=
0
;
...
...
@@ -1187,16 +1186,16 @@ int32_t filterAddGroupUnitFromNode(SFilterInfo *info, tExprNode* tree, SArray *g
}
if
(
tree
->
_node
.
optr
==
TSDB_RELATION_QUESTION
){
SSchema
*
schema
=
pLeft
->
pSchema
;
SSchema
*
schema
=
(
*
pLeft
)
->
pSchema
;
if
(
tree
->
_node
.
pRight
->
pVal
->
nLen
>
TSDB_MAX_JSON_KEY_LEN
)
return
TSDB_CODE_TSC_INVALID_COLUMN_LENGTH
;
char
keyMd5
[
TSDB_MAX_JSON_KEY_MD5_LEN
]
=
{
0
};
jsonKeyMd5
(
tree
->
_node
.
pRight
->
pVal
->
pz
,
tree
->
_node
.
pRight
->
pVal
->
nLen
,
keyMd5
);
memcpy
(
schema
->
name
,
keyMd5
,
TSDB_MAX_JSON_KEY_MD5_LEN
);
}
SSchema
*
schema
=
pLeft
->
pSchema
;
SSchema
*
schema
=
(
*
pLeft
)
->
pSchema
;
if
(
tree
->
_node
.
optr
==
TSDB_RELATION_ISNULL
||
tree
->
_node
.
optr
==
TSDB_RELATION_NOTNULL
){
if
(
pLeft
->
pSchema
->
type
==
TSDB_DATA_TYPE_JSON
)
{
if
(
(
*
pLeft
)
->
pSchema
->
type
==
TSDB_DATA_TYPE_JSON
)
{
char
keyMd5
[
TSDB_MAX_JSON_KEY_MD5_LEN
]
=
{
0
};
uint8_t
nullData
=
TSDB_DATA_JSON_NULL
;
jsonKeyMd5
(
&
nullData
,
1
,
keyMd5
);
...
...
@@ -1207,7 +1206,13 @@ int32_t filterAddGroupUnitFromNode(SFilterInfo *info, tExprNode* tree, SArray *g
return
TSDB_CODE_QRY_JSON_INVALID_EXP
;
}
}
return
TSDB_CODE_SUCCESS
;
}
int32_t
filterAddGroupUnitFromNode
(
SFilterInfo
*
info
,
tExprNode
*
tree
,
SArray
*
group
)
{
tExprNode
*
pLeft
=
tree
->
_node
.
pLeft
;
int32_t
ret
=
TSDB_CODE_SUCCESS
;
if
((
ret
=
filterDealJson
(
info
,
tree
,
&
pLeft
))
!=
TSDB_CODE_SUCCESS
)
return
ret
;
SFilterFieldId
left
=
{
0
},
right
=
{
0
};
filterAddFieldFromNode
(
info
,
pLeft
,
&
left
);
tVariant
*
var
=
tree
->
_node
.
pRight
->
pVal
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录