Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
ccbf0fdb
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ccbf0fdb
编写于
12月 02, 2021
作者:
wmmhello
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
enable different value type of the same key in json
上级
de52faff
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
25 addition
and
7 deletion
+25
-7
src/client/src/tscSubquery.c
src/client/src/tscSubquery.c
+7
-1
src/query/src/qExtbuffer.c
src/query/src/qExtbuffer.c
+7
-1
src/util/src/tcompare.c
src/util/src/tcompare.c
+9
-5
tests/pytest/stable/json_tag.py
tests/pytest/stable/json_tag.py
+2
-0
未找到文件。
src/client/src/tscSubquery.c
浏览文件 @
ccbf0fdb
...
...
@@ -756,9 +756,15 @@ int32_t tagValCompar(const void* p1, const void* p2) {
}
else
if
(
!
f1IsJsonNull
&&
f2IsJsonNull
)
{
return
1
;
}
if
(
*
t1
->
tag
!=
*
t2
->
tag
)
{
if
(
*
t1
->
tag
!=
*
t2
->
tag
&&
!
(
IS_NUMERIC_TYPE
(
*
t1
->
tag
)
&&
IS_NUMERIC_TYPE
(
*
t2
->
tag
))
)
{
return
1
;
}
if
(
*
t1
->
tag
==
TSDB_DATA_TYPE_BIGINT
&&
*
t2
->
tag
==
TSDB_DATA_TYPE_DOUBLE
){
DEFAULT_DOUBLE_COMP
(
GET_INT64_VAL
(
t1
->
tag
+
CHAR_BYTES
),
GET_DOUBLE_VAL
(
t2
->
tag
+
CHAR_BYTES
));
}
else
if
(
*
t1
->
tag
==
TSDB_DATA_TYPE_DOUBLE
&&
*
t2
->
tag
==
TSDB_DATA_TYPE_BIGINT
){
DEFAULT_DOUBLE_COMP
(
GET_DOUBLE_VAL
(
t1
->
tag
+
CHAR_BYTES
),
GET_INT64_VAL
(
t2
->
tag
+
CHAR_BYTES
));
}
__compar_fn_t
func
=
getComparFunc
(
t1
->
tag
[
0
],
0
);
return
func
(
t1
->
tag
+
CHAR_BYTES
,
t2
->
tag
+
CHAR_BYTES
);
}
...
...
src/query/src/qExtbuffer.c
浏览文件 @
ccbf0fdb
...
...
@@ -386,9 +386,15 @@ int32_t columnValueAscendingComparator(char *f1, char *f2, int32_t type, int32_t
}
else
if
(
!
f1IsJsonNull
&&
f2IsJsonNull
)
{
return
1
;
}
if
(
*
f1
!=
*
f2
)
{
if
(
*
f1
!=
*
f2
&&
!
(
IS_NUMERIC_TYPE
(
*
f1
)
&&
IS_NUMERIC_TYPE
(
*
f2
)))
{
return
1
;
}
if
(
*
f1
==
TSDB_DATA_TYPE_BIGINT
&&
*
f2
==
TSDB_DATA_TYPE_DOUBLE
){
DEFAULT_DOUBLE_COMP
(
GET_INT64_VAL
(
f1
+
CHAR_BYTES
),
GET_DOUBLE_VAL
(
f2
+
CHAR_BYTES
));
}
else
if
(
*
f1
==
TSDB_DATA_TYPE_DOUBLE
&&
*
f2
==
TSDB_DATA_TYPE_BIGINT
){
DEFAULT_DOUBLE_COMP
(
GET_DOUBLE_VAL
(
f1
+
CHAR_BYTES
),
GET_INT64_VAL
(
f2
+
CHAR_BYTES
));
}
type
=
*
f1
;
f1
+=
CHAR_BYTES
;
f2
+=
CHAR_BYTES
;
...
...
src/util/src/tcompare.c
浏览文件 @
ccbf0fdb
...
...
@@ -220,9 +220,6 @@ int32_t compareLenPrefixedWStrDesc(const void* pLeft, const void* pRight) {
}
int32_t
compareJsonVal
(
const
void
*
pLeft
,
const
void
*
pRight
)
{
if
(
*
(
char
*
)
pLeft
==
TSDB_DATA_TYPE_BINARY
){
// json null
return
-
1
;
}
const
tVariant
*
right
=
pRight
;
if
(
right
->
nType
!=
*
(
char
*
)
pLeft
&&
!
(
IS_NUMERIC_TYPE
(
right
->
nType
)
&&
IS_NUMERIC_TYPE
(
*
(
char
*
)
pLeft
)))
return
TSDB_DATA_JSON_CAN_NOT_COMPARE
;
...
...
@@ -244,6 +241,8 @@ int32_t compareJsonVal(const void *pLeft, const void *pRight) {
return
ret
;
}
return
(
ret
<
0
)
?
-
1
:
1
;
}
else
if
(
type
==
TSDB_DATA_TYPE_BINARY
)
{
//json null
return
0
;
}
else
{
assert
(
0
);
}
...
...
@@ -636,9 +635,14 @@ int32_t doCompare(const char* f1, const char* f2, int32_t type, size_t size) {
}
else
if
(
!
f1IsJsonNull
&&
f2IsJsonNull
)
{
return
1
;
}
if
(
*
f1
!=
*
f2
)
{
if
(
*
f1
!=
*
f2
&&
!
(
IS_NUMERIC_TYPE
(
*
f1
)
&&
IS_NUMERIC_TYPE
(
*
f2
))
)
{
return
1
;
}
if
(
*
f1
==
TSDB_DATA_TYPE_BIGINT
&&
*
f2
==
TSDB_DATA_TYPE_DOUBLE
){
DEFAULT_DOUBLE_COMP
(
GET_INT64_VAL
(
f1
+
CHAR_BYTES
),
GET_DOUBLE_VAL
(
f2
+
CHAR_BYTES
));
}
else
if
(
*
f1
==
TSDB_DATA_TYPE_DOUBLE
&&
*
f2
==
TSDB_DATA_TYPE_BIGINT
){
DEFAULT_DOUBLE_COMP
(
GET_DOUBLE_VAL
(
f1
+
CHAR_BYTES
),
GET_INT64_VAL
(
f2
+
CHAR_BYTES
));
}
type
=
*
f1
;
f1
+=
CHAR_BYTES
;
f2
+=
CHAR_BYTES
;
...
...
tests/pytest/stable/json_tag.py
浏览文件 @
ccbf0fdb
...
...
@@ -167,6 +167,8 @@ class TDTestCase:
tdSql
.
checkData
(
0
,
1
,
2
)
tdSql
.
query
(
"select * from jsons1 where jtag->'tag1'=10"
)
tdSql
.
checkRows
(
0
)
tdSql
.
query
(
"select * from jsons1 where jtag->'tag1'<54"
)
tdSql
.
checkRows
(
3
)
# where json value is double
tdSql
.
query
(
"select * from jsons1 where jtag->'tag1'=1.232"
)
tdSql
.
checkRows
(
1
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录