Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
a5be0d1a
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看板
提交
a5be0d1a
编写于
1月 21, 2022
作者:
G
Ganlin Zhao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[TD-11222]<feature>: Histogram function
上级
aaaf87c3
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
56 addition
and
2 deletion
+56
-2
src/client/src/tscSQLParser.c
src/client/src/tscSQLParser.c
+8
-1
tests/develop-test/2-query/function_histogram.py
tests/develop-test/2-query/function_histogram.py
+48
-1
未找到文件。
src/client/src/tscSQLParser.c
浏览文件 @
a5be0d1a
...
@@ -2680,6 +2680,7 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, SQueryInfo* pQueryInfo, int32_t col
...
@@ -2680,6 +2680,7 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, SQueryInfo* pQueryInfo, int32_t col
const
char
*
msg21
=
"third parameter must be in JSON format"
;
const
char
*
msg21
=
"third parameter must be in JSON format"
;
const
char
*
msg22
=
"invalid parameters for bin_desciption"
;
const
char
*
msg22
=
"invalid parameters for bin_desciption"
;
const
char
*
msg23
=
"parameter/bin out of range [-DBL_MAX, DBL_MAX]"
;
const
char
*
msg23
=
"parameter/bin out of range [-DBL_MAX, DBL_MAX]"
;
const
char
*
msg24
=
"linear_bin 'width' param cannot be 0"
;
switch
(
functionId
)
{
switch
(
functionId
)
{
case
TSDB_FUNC_COUNT
:
{
case
TSDB_FUNC_COUNT
:
{
...
@@ -3420,7 +3421,9 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, SQueryInfo* pQueryInfo, int32_t col
...
@@ -3420,7 +3421,9 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, SQueryInfo* pQueryInfo, int32_t col
return
invalidOperationMsg
(
tscGetErrorMsgPayload
(
pCmd
),
msg22
);
return
invalidOperationMsg
(
tscGetErrorMsgPayload
(
pCmd
),
msg22
);
}
}
if
(
isinf
(
start
->
valuedouble
)
||
isinf
(
width
->
valuedouble
))
{
if
(
isinf
(
start
->
valuedouble
)
||
(
width
!=
NULL
&&
isinf
(
width
->
valuedouble
))
||
(
factor
!=
NULL
&&
isinf
(
factor
->
valuedouble
)))
{
return
invalidOperationMsg
(
tscGetErrorMsgPayload
(
pCmd
),
msg23
);
return
invalidOperationMsg
(
tscGetErrorMsgPayload
(
pCmd
),
msg23
);
}
}
...
@@ -3436,6 +3439,10 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, SQueryInfo* pQueryInfo, int32_t col
...
@@ -3436,6 +3439,10 @@ int32_t addExprAndResultField(SSqlCmd* pCmd, SQueryInfo* pQueryInfo, int32_t col
intervals
=
tcalloc
(
numBins
,
sizeof
(
double
));
intervals
=
tcalloc
(
numBins
,
sizeof
(
double
));
if
(
cJSON_IsNumber
(
width
)
&&
factor
==
NULL
&&
binType
==
LINEAR_BIN
)
{
if
(
cJSON_IsNumber
(
width
)
&&
factor
==
NULL
&&
binType
==
LINEAR_BIN
)
{
//linear bin process
//linear bin process
if
(
width
->
valuedouble
==
0
)
{
tfree
(
intervals
);
return
invalidOperationMsg
(
tscGetErrorMsgPayload
(
pCmd
),
msg24
);
}
for
(
int
i
=
0
;
i
<
counter
+
1
;
++
i
)
{
for
(
int
i
=
0
;
i
<
counter
+
1
;
++
i
)
{
intervals
[
startIndex
]
=
start
->
valuedouble
+
i
*
width
->
valuedouble
;
intervals
[
startIndex
]
=
start
->
valuedouble
+
i
*
width
->
valuedouble
;
if
(
isinf
(
intervals
[
i
]))
{
if
(
isinf
(
intervals
[
i
]))
{
...
...
tests/develop-test/2-query/function_histogram.py
浏览文件 @
a5be0d1a
...
@@ -998,7 +998,54 @@ class TDTestCase:
...
@@ -998,7 +998,54 @@ class TDTestCase:
tdSql
.
checkData
(
1
,
0
,
"(-1.76e+308:-1.76e+308]:0"
);
tdSql
.
checkData
(
1
,
0
,
"(-1.76e+308:-1.76e+308]:0"
);
tdSql
.
checkData
(
2
,
0
,
"(-1.76e+308:1.79769e+308]:15"
);
tdSql
.
checkData
(
2
,
0
,
"(-1.76e+308:1.79769e+308]:15"
);
#tdSql.query('select histogram(col_tinyint, \'linear_bin\', \'{"start": -1.80e+308, "width": 5, "count": 5, "infinity": false}\', 0) from stb;')
tdSql
.
query
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -0.7e+308, "width": 0.7e+308, "count": 2, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
checkRows
(
2
);
tdSql
.
checkData
(
0
,
0
,
"(-7e+307:0]:2"
);
tdSql
.
checkData
(
1
,
0
,
"(0:7e+307]:13"
);
tdSql
.
query
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -0.7e+308, "width": 0.7e+308, "count": 2, "infinity": false}
\'
, 0) from ctb;'
)
tdSql
.
checkRows
(
2
);
tdSql
.
checkData
(
0
,
0
,
"(-7e+307:0]:2"
);
tdSql
.
checkData
(
1
,
0
,
"(0:7e+307]:13"
);
tdSql
.
query
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -0.7e+308, "width": 0.7e+308, "count": 2, "infinity": false}
\'
, 0) from tb;'
)
tdSql
.
checkRows
(
2
);
tdSql
.
checkData
(
0
,
0
,
"(-7e+307:0]:2"
);
tdSql
.
checkData
(
1
,
0
,
"(0:7e+307]:13"
);
tdSql
.
query
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -0.7e+308, "width": 0.7e+308, "count": 2, "infinity": true}
\'
, 0) from stb;'
)
tdSql
.
checkRows
(
4
);
tdSql
.
checkData
(
0
,
0
,
"(-1.79769e+308:-7e+307]:0"
);
tdSql
.
checkData
(
1
,
0
,
"(-7e+307:0]:2"
);
tdSql
.
checkData
(
2
,
0
,
"(0:7e+307]:13"
);
tdSql
.
checkData
(
3
,
0
,
"(7e+307:1.79769e+308]:0"
);
tdSql
.
query
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -0.7e+308, "width": 0.7e+308, "count": 2, "infinity": true}
\'
, 0) from ctb;'
)
tdSql
.
checkRows
(
4
);
tdSql
.
checkData
(
0
,
0
,
"(-1.79769e+308:-7e+307]:0"
);
tdSql
.
checkData
(
1
,
0
,
"(-7e+307:0]:2"
);
tdSql
.
checkData
(
2
,
0
,
"(0:7e+307]:13"
);
tdSql
.
checkData
(
3
,
0
,
"(7e+307:1.79769e+308]:0"
);
tdSql
.
query
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -0.7e+308, "width": 0.7e+308, "count": 2, "infinity": true}
\'
, 0) from tb;'
)
tdSql
.
checkRows
(
4
);
tdSql
.
checkData
(
0
,
0
,
"(-1.79769e+308:-7e+307]:0"
);
tdSql
.
checkData
(
1
,
0
,
"(-7e+307:0]:2"
);
tdSql
.
checkData
(
2
,
0
,
"(0:7e+307]:13"
);
tdSql
.
checkData
(
3
,
0
,
"(7e+307:1.79769e+308]:0"
);
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": true, "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": false, "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": "abc", "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": "中文", "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": abc, "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": -1.80e+308, "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 1.80e+308, "width": 5, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": true, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": false, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": "abc", "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": "中文", "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": abc, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": 0, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": -1.80e+308, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
tdSql
.
error
(
'select histogram(col_tinyint,
\'
linear_bin
\'
,
\'
{"start": 0, "width": 1.80e+308, "count": 5, "infinity": false}
\'
, 0) from stb;'
)
return
return
tdSql
.
execute
(
'drop database db'
)
tdSql
.
execute
(
'drop database db'
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录