Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
9b232e72
T
TDengine
项目概览
慢慢CG
/
TDengine
与 Fork 源项目一致
Fork自
taosdata / TDengine
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
9b232e72
编写于
4月 14, 2020
作者:
L
lihui
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[TD-140]
上级
5709b1aa
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
33 addition
and
14 deletion
+33
-14
src/client/src/tscFunctionImpl.c
src/client/src/tscFunctionImpl.c
+33
-14
未找到文件。
src/client/src/tscFunctionImpl.c
浏览文件 @
9b232e72
...
@@ -4444,7 +4444,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4444,7 +4444,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
pTrace
(
"%p rate_function() size:%d, hasNull:%d"
,
pCtx
,
pCtx
->
size
,
pCtx
->
hasNull
);
pTrace
(
"%p rate_function() size:%d, hasNull:%d"
,
pCtx
,
pCtx
->
size
,
pCtx
->
hasNull
);
if
(
pCtx
->
order
==
TSQL_SO_ASC
)
{
if
(
pCtx
->
order
==
TSQL_SO_ASC
)
{
/*
#ifdef NOT_EQUINIX
// prev interpolation exists
// prev interpolation exists
if
(
pCtx
->
prev
.
key
!=
-
1
)
{
if
(
pCtx
->
prev
.
key
!=
-
1
)
{
pRateInfo
->
firstValue
=
pCtx
->
prev
.
data
;
pRateInfo
->
firstValue
=
pCtx
->
prev
.
data
;
...
@@ -4464,7 +4465,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4464,7 +4465,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
pTrace
(
"lastValue:%f lastKey:%"
PRId64
,
pRateInfo
->
lastValue
,
pRateInfo
->
lastKey
);
pTrace
(
"lastValue:%f lastKey:%"
PRId64
,
pRateInfo
->
lastValue
,
pRateInfo
->
lastKey
);
}
}
}
}
*/
#endif
for
(
int32_t
i
=
0
;
i
<
pCtx
->
size
;
++
i
)
{
for
(
int32_t
i
=
0
;
i
<
pCtx
->
size
;
++
i
)
{
char
*
pData
=
GET_INPUT_CHAR_INDEX
(
pCtx
,
i
);
char
*
pData
=
GET_INPUT_CHAR_INDEX
(
pCtx
,
i
);
if
(
pCtx
->
hasNull
&&
isNull
(
pData
,
pCtx
->
inputType
))
{
if
(
pCtx
->
hasNull
&&
isNull
(
pData
,
pCtx
->
inputType
))
{
...
@@ -4520,7 +4522,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4520,7 +4522,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
if
(
!
pCtx
->
hasNull
)
{
if
(
!
pCtx
->
hasNull
)
{
assert
(
pCtx
->
size
==
notNullElems
);
assert
(
pCtx
->
size
==
notNullElems
);
}
}
/*
#ifdef NOT_EQUINIX
if
(
pCtx
->
next
.
key
!=
-
1
)
{
if
(
pCtx
->
next
.
key
!=
-
1
)
{
if
(
pCtx
->
next
.
data
<
pRateInfo
->
lastValue
)
{
if
(
pCtx
->
next
.
data
<
pRateInfo
->
lastValue
)
{
pRateInfo
->
CorrectionValue
+=
pRateInfo
->
lastValue
;
pRateInfo
->
CorrectionValue
+=
pRateInfo
->
lastValue
;
...
@@ -4531,9 +4534,10 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4531,9 +4534,10 @@ static void rate_function(SQLFunctionCtx *pCtx) {
pRateInfo
->
lastKey
=
pCtx
->
next
.
key
;
pRateInfo
->
lastKey
=
pCtx
->
next
.
key
;
pCtx
->
next
.
key
=
-
1
;
pCtx
->
next
.
key
=
-
1
;
pTrace
(
"%p get next interpolation for lastValue:%f lastKey:%"
PRId64
,
pCtx
,
pRateInfo
->
lastValue
,
pRateInfo
->
lastKey
);
pTrace
(
"%p get next interpolation for lastValue:%f lastKey:%"
PRId64
,
pCtx
,
pRateInfo
->
lastValue
,
pRateInfo
->
lastKey
);
}*/
}
#endif
}
else
{
}
else
{
/*
#ifdef NOT_EQUINIX
if
(
pCtx
->
next
.
key
!=
-
1
)
{
if
(
pCtx
->
next
.
key
!=
-
1
)
{
pRateInfo
->
lastValue
=
pCtx
->
next
.
data
;
pRateInfo
->
lastValue
=
pCtx
->
next
.
data
;
pRateInfo
->
lastKey
=
pCtx
->
next
.
key
;
pRateInfo
->
lastKey
=
pCtx
->
next
.
key
;
...
@@ -4551,7 +4555,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4551,7 +4555,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
pTrace
(
"firstValue:%f firstKey:%"
PRId64
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
pTrace
(
"firstValue:%f firstKey:%"
PRId64
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
}
}
}
}
*/
#endif
for
(
int32_t
i
=
pCtx
->
size
-
1
;
i
>=
0
;
--
i
)
{
for
(
int32_t
i
=
pCtx
->
size
-
1
;
i
>=
0
;
--
i
)
{
char
*
pData
=
GET_INPUT_CHAR_INDEX
(
pCtx
,
i
);
char
*
pData
=
GET_INPUT_CHAR_INDEX
(
pCtx
,
i
);
if
(
pCtx
->
hasNull
&&
isNull
(
pData
,
pCtx
->
inputType
))
{
if
(
pCtx
->
hasNull
&&
isNull
(
pData
,
pCtx
->
inputType
))
{
...
@@ -4607,7 +4612,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4607,7 +4612,8 @@ static void rate_function(SQLFunctionCtx *pCtx) {
if
(
!
pCtx
->
hasNull
)
{
if
(
!
pCtx
->
hasNull
)
{
assert
(
pCtx
->
size
==
notNullElems
);
assert
(
pCtx
->
size
==
notNullElems
);
}
}
/*
#ifdef NOT_EQUINIX
if
(
pCtx
->
prev
.
key
!=
-
1
)
{
if
(
pCtx
->
prev
.
key
!=
-
1
)
{
if
(
pCtx
->
prev
.
data
>
pRateInfo
->
firstValue
)
{
if
(
pCtx
->
prev
.
data
>
pRateInfo
->
firstValue
)
{
pRateInfo
->
CorrectionValue
+=
pCtx
->
prev
.
data
;
pRateInfo
->
CorrectionValue
+=
pCtx
->
prev
.
data
;
...
@@ -4619,7 +4625,7 @@ static void rate_function(SQLFunctionCtx *pCtx) {
...
@@ -4619,7 +4625,7 @@ static void rate_function(SQLFunctionCtx *pCtx) {
pCtx
->
prev
.
key
=
-
1
;
pCtx
->
prev
.
key
=
-
1
;
pTrace
(
"%p get prev interpolation for firstValue:%f firstKey:%"
PRId64
,
pCtx
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
pTrace
(
"%p get prev interpolation for firstValue:%f firstKey:%"
PRId64
,
pCtx
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
}
}
*/
#endif
};
};
SET_VAL
(
pCtx
,
notNullElems
,
1
);
SET_VAL
(
pCtx
,
notNullElems
,
1
);
...
@@ -4755,11 +4761,11 @@ static void rate_finalizer(SQLFunctionCtx *pCtx) {
...
@@ -4755,11 +4761,11 @@ static void rate_finalizer(SQLFunctionCtx *pCtx) {
pTrace
(
"%p isIRate:%d firstKey:%"
PRId64
" lastKey:%"
PRId64
" firstValue:%f lastValue:%f CorrectionValue:%f hasResult:%d"
,
pTrace
(
"%p isIRate:%d firstKey:%"
PRId64
" lastKey:%"
PRId64
" firstValue:%f lastValue:%f CorrectionValue:%f hasResult:%d"
,
pCtx
,
pRateInfo
->
isIRate
,
pRateInfo
->
firstKey
,
pRateInfo
->
lastKey
,
pRateInfo
->
firstValue
,
pRateInfo
->
lastValue
,
pRateInfo
->
CorrectionValue
,
pRateInfo
->
hasResult
);
pCtx
,
pRateInfo
->
isIRate
,
pRateInfo
->
firstKey
,
pRateInfo
->
lastKey
,
pRateInfo
->
firstValue
,
pRateInfo
->
lastValue
,
pRateInfo
->
CorrectionValue
,
pRateInfo
->
hasResult
);
if
(
pRateInfo
->
hasResult
!=
DATA_SET_FLAG
)
{
if
(
(
pRateInfo
->
hasResult
!=
DATA_SET_FLAG
)
||
(
INT64_MIN
==
pRateInfo
->
lastKey
)
||
(
INT64_MIN
==
pRateInfo
->
firstKey
)
)
{
setNull
(
pCtx
->
aOutputBuf
,
TSDB_DATA_TYPE_DOUBLE
,
sizeof
(
double
));
setNull
(
pCtx
->
aOutputBuf
,
TSDB_DATA_TYPE_DOUBLE
,
sizeof
(
double
));
return
;
return
;
}
}
*
(
double
*
)
pCtx
->
aOutputBuf
=
do_calc_rate
(
pRateInfo
);
*
(
double
*
)
pCtx
->
aOutputBuf
=
do_calc_rate
(
pRateInfo
);
pTrace
(
"rate_finalizer() output result:%f"
,
*
(
double
*
)
pCtx
->
aOutputBuf
);
pTrace
(
"rate_finalizer() output result:%f"
,
*
(
double
*
)
pCtx
->
aOutputBuf
);
...
@@ -4786,7 +4792,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
...
@@ -4786,7 +4792,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
if
(
pCtx
->
size
<
1
)
{
if
(
pCtx
->
size
<
1
)
{
return
;
return
;
}
}
/*
#ifdef NOT_EQUINIX
// next interpolation exists
// next interpolation exists
if
(
pCtx
->
next
.
key
!=
-
1
)
{
if
(
pCtx
->
next
.
key
!=
-
1
)
{
pRateInfo
->
lastValue
=
pCtx
->
next
.
data
;
pRateInfo
->
lastValue
=
pCtx
->
next
.
data
;
...
@@ -4794,7 +4801,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
...
@@ -4794,7 +4801,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
pCtx
->
next
.
key
=
-
1
;
// clear the flag
pCtx
->
next
.
key
=
-
1
;
// clear the flag
pTrace
(
"%p irate_function() get next interpolation for lastValue:%f lastKey:%"
PRId64
,
pCtx
,
pRateInfo
->
lastValue
,
pRateInfo
->
lastKey
);
pTrace
(
"%p irate_function() get next interpolation for lastValue:%f lastKey:%"
PRId64
,
pCtx
,
pRateInfo
->
lastValue
,
pRateInfo
->
lastKey
);
}
}
*/
#endif
for
(
int32_t
i
=
pCtx
->
size
-
1
;
i
>=
0
;
--
i
)
{
for
(
int32_t
i
=
pCtx
->
size
-
1
;
i
>=
0
;
--
i
)
{
char
*
pData
=
GET_INPUT_CHAR_INDEX
(
pCtx
,
i
);
char
*
pData
=
GET_INPUT_CHAR_INDEX
(
pCtx
,
i
);
if
(
pCtx
->
hasNull
&&
isNull
(
pData
,
pCtx
->
inputType
))
{
if
(
pCtx
->
hasNull
&&
isNull
(
pData
,
pCtx
->
inputType
))
{
...
@@ -4842,7 +4850,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
...
@@ -4842,7 +4850,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
pTrace
(
"%p irate_function() firstValue:%f firstKey:%"
PRId64
,
pCtx
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
pTrace
(
"%p irate_function() firstValue:%f firstKey:%"
PRId64
,
pCtx
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
break
;
break
;
}
}
/*
#ifdef NOT_EQUINIX
if
(
pCtx
->
prev
.
key
!=
-
1
)
{
if
(
pCtx
->
prev
.
key
!=
-
1
)
{
if
((
INT64_MIN
==
pRateInfo
->
firstKey
)
||
(
-
DBL_MAX
==
pRateInfo
->
firstValue
))
{
if
((
INT64_MIN
==
pRateInfo
->
firstKey
)
||
(
-
DBL_MAX
==
pRateInfo
->
firstValue
))
{
pRateInfo
->
firstValue
=
pCtx
->
prev
.
data
;
pRateInfo
->
firstValue
=
pCtx
->
prev
.
data
;
...
@@ -4851,7 +4860,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
...
@@ -4851,7 +4860,8 @@ static void irate_function(SQLFunctionCtx *pCtx) {
pTrace
(
"%p irate_function() get prev interpolation for firstValue:%f firstKey:%"
PRId64
,
pCtx
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
pTrace
(
"%p irate_function() get prev interpolation for firstValue:%f firstKey:%"
PRId64
,
pCtx
,
pRateInfo
->
firstValue
,
pRateInfo
->
firstKey
);
}
}
}
}
*/
#endif
SET_VAL
(
pCtx
,
notNullElems
,
1
);
SET_VAL
(
pCtx
,
notNullElems
,
1
);
if
(
notNullElems
>
0
)
{
if
(
notNullElems
>
0
)
{
...
@@ -4935,6 +4945,10 @@ static void do_sumrate_merge(SQLFunctionCtx *pCtx) {
...
@@ -4935,6 +4945,10 @@ static void do_sumrate_merge(SQLFunctionCtx *pCtx) {
if
(
pInput
->
hasResult
!=
DATA_SET_FLAG
)
{
if
(
pInput
->
hasResult
!=
DATA_SET_FLAG
)
{
continue
;
continue
;
}
else
if
(
pInput
->
num
==
0
)
{
}
else
if
(
pInput
->
num
==
0
)
{
if
((
INT64_MIN
==
pRateInfo
->
lastKey
)
||
(
INT64_MIN
==
pRateInfo
->
firstKey
))
{
continue
;
}
pRateInfo
->
sum
+=
do_calc_rate
(
pInput
);
pRateInfo
->
sum
+=
do_calc_rate
(
pInput
);
pRateInfo
->
num
++
;
pRateInfo
->
num
++
;
}
else
{
}
else
{
...
@@ -4975,6 +4989,11 @@ static void sumrate_finalizer(SQLFunctionCtx *pCtx) {
...
@@ -4975,6 +4989,11 @@ static void sumrate_finalizer(SQLFunctionCtx *pCtx) {
if
(
pRateInfo
->
num
==
0
)
{
if
(
pRateInfo
->
num
==
0
)
{
// from meter
// from meter
if
((
INT64_MIN
==
pRateInfo
->
lastKey
)
||
(
INT64_MIN
==
pRateInfo
->
firstKey
))
{
setNull
(
pCtx
->
aOutputBuf
,
TSDB_DATA_TYPE_DOUBLE
,
sizeof
(
double
));
return
;
}
*
(
double
*
)
pCtx
->
aOutputBuf
=
do_calc_rate
(
pRateInfo
);
*
(
double
*
)
pCtx
->
aOutputBuf
=
do_calc_rate
(
pRateInfo
);
}
else
if
(
pCtx
->
functionId
==
TSDB_FUNC_SUM_RATE
||
pCtx
->
functionId
==
TSDB_FUNC_SUM_IRATE
)
{
}
else
if
(
pCtx
->
functionId
==
TSDB_FUNC_SUM_RATE
||
pCtx
->
functionId
==
TSDB_FUNC_SUM_IRATE
)
{
*
(
double
*
)
pCtx
->
aOutputBuf
=
pRateInfo
->
sum
;
*
(
double
*
)
pCtx
->
aOutputBuf
=
pRateInfo
->
sum
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录