Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
f3b34b1e
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看板
提交
f3b34b1e
编写于
10月 22, 2021
作者:
S
shenglian zhou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[TD-10735]<fix>:use different cumsum type for signed/unsigned/double input type
上级
30e7b87c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
34 addition
and
9 deletion
+34
-9
src/query/src/qAggMain.c
src/query/src/qAggMain.c
+22
-9
tests/script/general/compute/csum.sim
tests/script/general/compute/csum.sim
+12
-0
未找到文件。
src/query/src/qAggMain.c
浏览文件 @
f3b34b1e
...
@@ -20,7 +20,6 @@
...
@@ -20,7 +20,6 @@
#include "tdigest.h"
#include "tdigest.h"
#include "ttype.h"
#include "ttype.h"
#include "tsdb.h"
#include "tsdb.h"
#include "tglobal.h"
#include "qAggMain.h"
#include "qAggMain.h"
#include "qFill.h"
#include "qFill.h"
...
@@ -172,7 +171,11 @@ typedef struct SDerivInfo {
...
@@ -172,7 +171,11 @@ typedef struct SDerivInfo {
}
SDerivInfo
;
}
SDerivInfo
;
typedef
struct
{
typedef
struct
{
double
cumSum
;
union
{
double
d64CumSum
;
int64_t
i64CumSum
;
uint64_t
u64CumSum
;
};
}
SCumSumInfo
;
}
SCumSumInfo
;
typedef
struct
{
typedef
struct
{
...
@@ -4709,7 +4712,7 @@ static bool csum_function_setup(SQLFunctionCtx *pCtx, SResultRowCellInfo* pResIn
...
@@ -4709,7 +4712,7 @@ static bool csum_function_setup(SQLFunctionCtx *pCtx, SResultRowCellInfo* pResIn
}
}
SCumSumInfo
*
pCumSumInfo
=
GET_ROWCELL_INTERBUF
(
pResInfo
);
SCumSumInfo
*
pCumSumInfo
=
GET_ROWCELL_INTERBUF
(
pResInfo
);
pCumSumInfo
->
c
umSum
=
0
;
pCumSumInfo
->
i64C
umSum
=
0
;
return
true
;
return
true
;
}
}
...
@@ -4733,20 +4736,30 @@ static void csum_function(SQLFunctionCtx *pCtx) {
...
@@ -4733,20 +4736,30 @@ static void csum_function(SQLFunctionCtx *pCtx) {
continue
;
continue
;
}
}
double
v
=
0
;
if
(
IS_SIGNED_NUMERIC_TYPE
(
pCtx
->
inputType
))
{
GET_TYPED_DATA
(
v
,
double
,
pCtx
->
inputType
,
pData
);
int64_t
v
=
0
;
pCumSumInfo
->
cumSum
+=
v
;
GET_TYPED_DATA
(
v
,
int64_t
,
pCtx
->
inputType
,
pData
);
pCumSumInfo
->
i64CumSum
+=
v
;
}
else
if
(
IS_UNSIGNED_NUMERIC_TYPE
(
pCtx
->
inputType
))
{
uint64_t
v
=
0
;
GET_TYPED_DATA
(
v
,
uint64_t
,
pCtx
->
inputType
,
pData
);
pCumSumInfo
->
u64CumSum
+=
v
;
}
else
if
(
IS_FLOAT_TYPE
(
pCtx
->
inputType
))
{
double
v
=
0
;
GET_TYPED_DATA
(
v
,
double
,
pCtx
->
inputType
,
pData
);
pCumSumInfo
->
d64CumSum
+=
v
;
}
*
pTimestamp
=
(
tsList
!=
NULL
)
?
tsList
[
i
]
:
0
;
*
pTimestamp
=
(
tsList
!=
NULL
)
?
tsList
[
i
]
:
0
;
if
(
IS_SIGNED_NUMERIC_TYPE
(
pCtx
->
inputType
))
{
if
(
IS_SIGNED_NUMERIC_TYPE
(
pCtx
->
inputType
))
{
int64_t
*
retVal
=
(
int64_t
*
)
pCtx
->
pOutput
;
int64_t
*
retVal
=
(
int64_t
*
)
pCtx
->
pOutput
;
*
retVal
=
(
int64_t
)(
pCumSumInfo
->
c
umSum
);
*
retVal
=
(
int64_t
)(
pCumSumInfo
->
i64C
umSum
);
}
else
if
(
IS_UNSIGNED_NUMERIC_TYPE
(
pCtx
->
inputType
))
{
}
else
if
(
IS_UNSIGNED_NUMERIC_TYPE
(
pCtx
->
inputType
))
{
uint64_t
*
retVal
=
(
uint64_t
*
)
pCtx
->
pOutput
;
uint64_t
*
retVal
=
(
uint64_t
*
)
pCtx
->
pOutput
;
*
retVal
=
(
uint64_t
)(
pCumSumInfo
->
c
umSum
);
*
retVal
=
(
uint64_t
)(
pCumSumInfo
->
u64C
umSum
);
}
else
if
(
IS_FLOAT_TYPE
(
pCtx
->
inputType
))
{
}
else
if
(
IS_FLOAT_TYPE
(
pCtx
->
inputType
))
{
double
*
retVal
=
(
double
*
)
pCtx
->
pOutput
;
double
*
retVal
=
(
double
*
)
pCtx
->
pOutput
;
SET_DOUBLE_VAL
(
retVal
,
pCumSumInfo
->
c
umSum
);
SET_DOUBLE_VAL
(
retVal
,
pCumSumInfo
->
d64C
umSum
);
}
}
++
notNullElems
;
++
notNullElems
;
...
...
tests/script/general/compute/csum.sim
浏览文件 @
f3b34b1e
...
@@ -88,6 +88,18 @@ sql select csum(tbcol) as b from $tb where ts <= $ms interval(1m) -x step6
...
@@ -88,6 +88,18 @@ sql select csum(tbcol) as b from $tb where ts <= $ms interval(1m) -x step6
return -1
return -1
step6:
step6:
print =============== csum result overflow follow sum behavior
sql create table overflow(ts timestamp, c1 bigint)
sql insert into overflow values(now-1s, NULL)(now, 9223372036854775807)(now+1s, 9223372036854775807)
sql select csum(c1) from overflow
print $data00 , $data01, $data10, $data11
if $data01 != 9223372036854775807 then
return -1
endi
if $data11 != -2 then
return -1
endi
print =============== clear
print =============== clear
sql drop database $db
sql drop database $db
sql show databases
sql show databases
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录