Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
c74c52d1
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看板
未验证
提交
c74c52d1
编写于
7月 27, 2022
作者:
G
Ganlin Zhao
提交者:
GitHub
7月 27, 2022
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #15443 from taosdata/enh/TD-17659
fix(query): fix sum/max/min null input
上级
6a8c1e4f
c087a8d5
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
12 addition
and
11 deletion
+12
-11
source/libs/function/src/builtinsimpl.c
source/libs/function/src/builtinsimpl.c
+4
-3
tests/script/tsim/stream/session0.sim
tests/script/tsim/stream/session0.sim
+8
-8
未找到文件。
source/libs/function/src/builtinsimpl.c
浏览文件 @
c74c52d1
...
...
@@ -466,7 +466,7 @@ int32_t functionFinalize(SqlFunctionCtx* pCtx, SSDataBlock* pBlock) {
SColumnInfoData
*
pCol
=
taosArrayGet
(
pBlock
->
pDataBlock
,
slotId
);
SResultRowEntryInfo
*
pResInfo
=
GET_RES_INFO
(
pCtx
);
pResInfo
->
isNullRes
=
(
pResInfo
->
numOfRes
==
0
)
?
1
:
0
;
pResInfo
->
isNullRes
=
(
pResInfo
->
isNullRes
==
1
)
?
1
:
(
pResInfo
->
numOfRes
==
0
)
;
char
*
in
=
GET_ROWCELL_INTERBUF
(
pResInfo
);
colDataAppend
(
pCol
,
pBlock
->
info
.
rows
,
in
,
pResInfo
->
isNullRes
);
...
...
@@ -663,7 +663,8 @@ int32_t sumFunction(SqlFunctionCtx* pCtx) {
// check for overflow
if
(
IS_FLOAT_TYPE
(
type
)
&&
(
isinf
(
pSumRes
->
dsum
)
||
isnan
(
pSumRes
->
dsum
)))
{
numOfElem
=
0
;
GET_RES_INFO
(
pCtx
)
->
isNullRes
=
1
;
numOfElem
=
1
;
}
_sum_over:
...
...
@@ -1605,7 +1606,7 @@ int32_t minmaxFunctionFinalize(SqlFunctionCtx* pCtx, SSDataBlock* pBlock) {
int32_t
currentRow
=
pBlock
->
info
.
rows
;
SColumnInfoData
*
pCol
=
taosArrayGet
(
pBlock
->
pDataBlock
,
slotId
);
pEntryInfo
->
isNullRes
=
(
pEntryInfo
->
numOfRes
==
0
);
pEntryInfo
->
isNullRes
=
(
pEntryInfo
->
isNullRes
==
1
)
?
1
:
(
pEntryInfo
->
numOfRes
==
0
);
if
(
pCol
->
info
.
type
==
TSDB_DATA_TYPE_FLOAT
)
{
float
v
=
*
(
double
*
)
&
pRes
->
v
;
...
...
tests/script/tsim/stream/session0.sim
浏览文件 @
c74c52d1
...
...
@@ -83,22 +83,22 @@ if $data11 != 3 then
goto loop0
endi
if $data12 !=
10
then
if $data12 !=
NULL
then
print ======data12=$data12
goto loop0
endi
if $data13 !=
10
then
if $data13 !=
NULL
then
print ======data13=$data13
goto loop0
endi
if $data14 !=
1.100000000
then
if $data14 !=
NULL
then
print ======data14=$data14
return -1
endi
if $data15 !=
0.000000000
then
if $data15 !=
NULL
then
print ======data15=$data15
return -1
endi
...
...
@@ -141,22 +141,22 @@ if $data01 != 7 then
goto loop1
endi
if $data02 !=
18
then
if $data02 !=
NULL
then
print =====data02=$data02
goto loop1
endi
if $data03 !=
4
then
if $data03 !=
NULL
then
print =====data03=$data03
goto loop1
endi
if $data04 !=
1.000000000
then
if $data04 !=
NULL
then
print ======$data04
return -1
endi
if $data05 !=
1.154700538
then
if $data05 !=
NULL
then
print ======$data05
return -1
endi
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录