Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
e74c0ac9
TDengine
项目概览
taosdata
/
TDengine
大约 1 年 前同步成功
通知
1184
Star
22015
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
e74c0ac9
编写于
6月 16, 2023
作者:
G
Ganlin Zhao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
save index instead of ts
上级
fe2629d0
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
12 addition
and
17 deletion
+12
-17
source/libs/executor/src/timesliceoperator.c
source/libs/executor/src/timesliceoperator.c
+12
-17
未找到文件。
source/libs/executor/src/timesliceoperator.c
浏览文件 @
e74c0ac9
...
...
@@ -45,7 +45,7 @@ typedef struct STimeSliceOperatorInfo {
SGroupKeys
*
pPrevGroupKey
;
SSDataBlock
*
pNextGroupRes
;
SSDataBlock
*
pRemainRes
;
// save block unfinished processing
int
64_t
remainTs
;
// the remaining timestamp
in the block to be processed
int
32_t
remainIndex
;
// the remaining index
in the block to be processed
}
STimeSliceOperatorInfo
;
static
void
destroyTimeSliceOperatorInfo
(
void
*
param
);
...
...
@@ -669,8 +669,13 @@ static void saveBlockStatus(STimeSliceOperatorInfo* pSliceInfo, SSDataBlock* pBl
SColumnInfoData
*
pTsCol
=
taosArrayGet
(
pBlock
->
pDataBlock
,
pSliceInfo
->
tsCol
.
slotId
);
if
(
curIndex
<
pBlock
->
info
.
rows
-
1
)
{
pSliceInfo
->
pRemainRes
=
pBlock
;
pSliceInfo
->
remainTs
=
*
(
int64_t
*
)
colDataGetData
(
pTsCol
,
curIndex
+
1
);
pSliceInfo
->
remainIndex
=
curIndex
+
1
;
return
;
}
// all data in remaining block processed
pSliceInfo
->
pRemainRes
=
NULL
;
}
static
void
doTimesliceImpl
(
SOperatorInfo
*
pOperator
,
STimeSliceOperatorInfo
*
pSliceInfo
,
SSDataBlock
*
pBlock
,
...
...
@@ -679,14 +684,10 @@ static void doTimesliceImpl(SOperatorInfo* pOperator, STimeSliceOperatorInfo* pS
SInterval
*
pInterval
=
&
pSliceInfo
->
interval
;
SColumnInfoData
*
pTsCol
=
taosArrayGet
(
pBlock
->
pDataBlock
,
pSliceInfo
->
tsCol
.
slotId
);
for
(
int32_t
i
=
0
;
i
<
pBlock
->
info
.
rows
;
++
i
)
{
int64_t
ts
=
*
(
int64_t
*
)
colDataGetData
(
pTsCol
,
i
);
// check if need to resume from the position of last unfinished block
if
(
pSliceInfo
->
pRemainRes
!=
NULL
&&
ts
<
pSliceInfo
->
remainTs
&&
pSliceInfo
->
current
<=
pSliceInfo
->
remainTs
)
{
continue
;
}
int32_t
i
=
(
pSliceInfo
->
pRemainRes
==
NULL
)
?
0
:
pSliceInfo
->
remainIndex
;
for
(;
i
<
pBlock
->
info
.
rows
;
++
i
)
{
int64_t
ts
=
*
(
int64_t
*
)
colDataGetData
(
pTsCol
,
i
);
// check for duplicate timestamps
if
(
checkDuplicateTimestamps
(
pSliceInfo
,
pTsCol
,
i
,
pBlock
->
info
.
rows
))
{
...
...
@@ -696,13 +697,6 @@ static void doTimesliceImpl(SOperatorInfo* pOperator, STimeSliceOperatorInfo* pS
if
(
checkNullRow
(
&
pOperator
->
exprSupp
,
pBlock
,
i
,
ignoreNull
))
{
continue
;
}
if
(
checkWindowBoundReached
(
pSliceInfo
))
{
break
;
}
if
(
checkThresholdReached
(
pSliceInfo
,
pOperator
->
resultInfo
.
threshold
))
{
saveBlockStatus
(
pSliceInfo
,
pBlock
,
i
);
return
;
}
if
(
ts
==
pSliceInfo
->
current
)
{
addCurrentRowToResult
(
pSliceInfo
,
&
pOperator
->
exprSupp
,
pResBlock
,
pBlock
,
i
);
...
...
@@ -984,7 +978,8 @@ SOperatorInfo* createTimeSliceOperatorInfo(SOperatorInfo* downstream, SPhysiNode
pInfo
->
pPrevGroupKey
=
NULL
;
pInfo
->
pNextGroupRes
=
NULL
;
pInfo
->
pRemainRes
=
NULL
;
pInfo
->
remainTs
=
0
;
pInfo
->
remainIndex
=
0
;
pOperator
->
resultInfo
.
threshold
=
1
;
if
(
downstream
->
operatorType
==
QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN
)
{
STableScanInfo
*
pScanInfo
=
(
STableScanInfo
*
)
downstream
->
info
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录