Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
c15c88df
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
提交
c15c88df
编写于
2月 17, 2022
作者:
H
Haojun Liao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[td-11818] add table id for streamscan operator.
上级
d6fa853b
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
47 addition
and
15 deletion
+47
-15
example/src/tmq.c
example/src/tmq.c
+10
-10
include/libs/executor/executor.h
include/libs/executor/executor.h
+12
-1
source/libs/executor/src/executor.c
source/libs/executor/src/executor.c
+22
-0
source/libs/executor/src/executorimpl.c
source/libs/executor/src/executorimpl.c
+3
-4
未找到文件。
example/src/tmq.c
浏览文件 @
c15c88df
...
@@ -28,7 +28,7 @@ int32_t init_env() {
...
@@ -28,7 +28,7 @@ int32_t init_env() {
return
-
1
;
return
-
1
;
}
}
TAOS_RES
*
pRes
=
taos_query
(
pConn
,
"create database if not exists abc1 vgroups
1
"
);
TAOS_RES
*
pRes
=
taos_query
(
pConn
,
"create database if not exists abc1 vgroups
2
"
);
if
(
taos_errno
(
pRes
)
!=
0
)
{
if
(
taos_errno
(
pRes
)
!=
0
)
{
printf
(
"error in create db, reason:%s
\n
"
,
taos_errstr
(
pRes
));
printf
(
"error in create db, reason:%s
\n
"
,
taos_errstr
(
pRes
));
return
-
1
;
return
-
1
;
...
@@ -56,14 +56,14 @@ int32_t init_env() {
...
@@ -56,14 +56,14 @@ int32_t init_env() {
}
}
taos_free_result
(
pRes
);
taos_free_result
(
pRes
);
pRes
=
taos_query
(
pConn
,
"create table if not exists tu2
using st1 tags(2)"
);
// pRes = taos_query(pConn, "create table if not exists tu6
using st1 tags(2)");
if
(
taos_errno
(
pRes
)
!=
0
)
{
//
if (taos_errno(pRes) != 0) {
printf
(
"failed to create child table tu2, reason:%s
\n
"
,
taos_errstr
(
pRes
));
//
printf("failed to create child table tu2, reason:%s\n", taos_errstr(pRes));
return
-
1
;
//
return -1;
}
//
}
taos_free_result
(
pRes
);
//
taos_free_result(pRes);
const
char
*
sql
=
"select * from
tu
1"
;
const
char
*
sql
=
"select * from
st
1"
;
pRes
=
tmq_create_topic
(
pConn
,
"test_stb_topic_1"
,
sql
,
strlen
(
sql
));
pRes
=
tmq_create_topic
(
pConn
,
"test_stb_topic_1"
,
sql
,
strlen
(
sql
));
if
(
taos_errno
(
pRes
)
!=
0
)
{
if
(
taos_errno
(
pRes
)
!=
0
)
{
printf
(
"failed to create topic test_stb_topic_1, reason:%s
\n
"
,
taos_errstr
(
pRes
));
printf
(
"failed to create topic test_stb_topic_1, reason:%s
\n
"
,
taos_errstr
(
pRes
));
...
@@ -197,7 +197,7 @@ int main() {
...
@@ -197,7 +197,7 @@ int main() {
code
=
init_env
();
code
=
init_env
();
tmq_t
*
tmq
=
build_consumer
();
tmq_t
*
tmq
=
build_consumer
();
tmq_list_t
*
topic_list
=
build_topic_list
();
tmq_list_t
*
topic_list
=
build_topic_list
();
perf_loop
(
tmq
,
topic_list
);
//
perf_loop(tmq, topic_list);
/*basic_consume_loop(tmq, topic_list);*/
basic_consume_loop
(
tmq
,
topic_list
);
/*sync_consume_loop(tmq, topic_list);*/
/*sync_consume_loop(tmq, topic_list);*/
}
}
include/libs/executor/executor.h
浏览文件 @
c15c88df
...
@@ -31,6 +31,7 @@ typedef struct SReadHandle {
...
@@ -31,6 +31,7 @@ typedef struct SReadHandle {
void
*
reader
;
void
*
reader
;
void
*
meta
;
void
*
meta
;
}
SReadHandle
;
}
SReadHandle
;
/**
/**
* Create the exec task for streaming mode
* Create the exec task for streaming mode
* @param pMsg
* @param pMsg
...
@@ -40,13 +41,23 @@ typedef struct SReadHandle {
...
@@ -40,13 +41,23 @@ typedef struct SReadHandle {
qTaskInfo_t
qCreateStreamExecTaskInfo
(
void
*
msg
,
void
*
streamReadHandle
);
qTaskInfo_t
qCreateStreamExecTaskInfo
(
void
*
msg
,
void
*
streamReadHandle
);
/**
/**
*
*
Set the input data block for the stream scan.
* @param tinfo
* @param tinfo
* @param input
* @param input
* @return
* @return
*/
*/
int32_t
qSetStreamInput
(
qTaskInfo_t
tinfo
,
const
void
*
input
);
int32_t
qSetStreamInput
(
qTaskInfo_t
tinfo
,
const
void
*
input
);
/**
* Update the table id list, add or remove.
*
* @param tinfo
* @param id
* @param isAdd
* @return
*/
int32_t
qUpdateTQualifiedTableId
(
qTaskInfo_t
tinfo
,
SArray
*
tableIdList
,
bool
isAdd
);
/**
/**
* Create the exec task object according to task json
* Create the exec task object according to task json
* @param readHandle
* @param readHandle
...
...
source/libs/executor/src/executor.c
浏览文件 @
c15c88df
...
@@ -90,3 +90,25 @@ qTaskInfo_t qCreateStreamExecTaskInfo(void* msg, void* streamReadHandle) {
...
@@ -90,3 +90,25 @@ qTaskInfo_t qCreateStreamExecTaskInfo(void* msg, void* streamReadHandle) {
return
pTaskInfo
;
return
pTaskInfo
;
}
}
int32_t
qUpdateTQualifiedTableId
(
qTaskInfo_t
tinfo
,
SArray
*
tableIdList
,
bool
isAdd
)
{
SExecTaskInfo
*
pTaskInfo
=
(
SExecTaskInfo
*
)
tinfo
;
// traverse to the streamscan node to add this table id
SOperatorInfo
*
pInfo
=
pTaskInfo
->
pRoot
;
while
(
pInfo
->
operatorType
!=
OP_StreamScan
)
{
pInfo
=
pInfo
->
pDownstream
[
0
];
}
SStreamBlockScanInfo
*
pScanInfo
=
pInfo
->
info
;
if
(
isAdd
)
{
int32_t
code
=
tqReadHandleSetTbUidList
(
pScanInfo
->
readerHandle
,
tableIdList
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
return
code
;
}
}
else
{
assert
(
0
);
}
return
TSDB_CODE_SUCCESS
;
}
\ No newline at end of file
source/libs/executor/src/executorimpl.c
浏览文件 @
c15c88df
...
@@ -5441,7 +5441,6 @@ SOperatorInfo* createStreamScanOperatorInfo(void *streamReadHandle, SArray* pExp
...
@@ -5441,7 +5441,6 @@ SOperatorInfo* createStreamScanOperatorInfo(void *streamReadHandle, SArray* pExp
SArray
*
pColList
=
taosArrayInit
(
numOfOutput
,
sizeof
(
int32_t
));
SArray
*
pColList
=
taosArrayInit
(
numOfOutput
,
sizeof
(
int32_t
));
for
(
int32_t
i
=
0
;
i
<
numOfOutput
;
++
i
)
{
for
(
int32_t
i
=
0
;
i
<
numOfOutput
;
++
i
)
{
SExprInfo
*
pExpr
=
taosArrayGetP
(
pExprInfo
,
i
);
SExprInfo
*
pExpr
=
taosArrayGetP
(
pExprInfo
,
i
);
taosArrayPush
(
pColList
,
&
pExpr
->
pExpr
->
pSchema
[
0
].
colId
);
taosArrayPush
(
pColList
,
&
pExpr
->
pExpr
->
pSchema
[
0
].
colId
);
}
}
...
@@ -5624,7 +5623,7 @@ static SExprInfo* exprArrayDup(SArray* pExprInfo) {
...
@@ -5624,7 +5623,7 @@ static SExprInfo* exprArrayDup(SArray* pExprInfo) {
return
p
;
return
p
;
}
}
static
SSDataBlock
*
doSortMerge
(
void
*
param
,
bool
*
newgroup
)
{
static
SSDataBlock
*
doSort
ed
Merge
(
void
*
param
,
bool
*
newgroup
)
{
SOperatorInfo
*
pOperator
=
(
SOperatorInfo
*
)
param
;
SOperatorInfo
*
pOperator
=
(
SOperatorInfo
*
)
param
;
if
(
pOperator
->
status
==
OP_EXEC_DONE
)
{
if
(
pOperator
->
status
==
OP_EXEC_DONE
)
{
return
NULL
;
return
NULL
;
...
@@ -5635,7 +5634,7 @@ static SSDataBlock* doSortMerge(void* param, bool* newgroup) {
...
@@ -5635,7 +5634,7 @@ static SSDataBlock* doSortMerge(void* param, bool* newgroup) {
for
(
int32_t
i
=
0
;
i
<
pInfo
->
numOfSources
;
++
i
)
{
for
(
int32_t
i
=
0
;
i
<
pInfo
->
numOfSources
;
++
i
)
{
SSDataBlock
*
pBlock
=
pOperator
->
pDownstream
[
i
]
->
exec
(
pOperator
->
pDownstream
[
i
],
newgroup
);
SSDataBlock
*
pBlock
=
pOperator
->
pDownstream
[
i
]
->
exec
(
pOperator
->
pDownstream
[
i
],
newgroup
);
// TODO set the order input sources.
}
}
return
NULL
;
return
NULL
;
...
@@ -5679,7 +5678,7 @@ SOperatorInfo* createSortMergeOperatorInfo(SOperatorInfo* downstream, SArray* pE
...
@@ -5679,7 +5678,7 @@ SOperatorInfo* createSortMergeOperatorInfo(SOperatorInfo* downstream, SArray* pE
pOperator
->
numOfOutput
=
numOfOutput
;
pOperator
->
numOfOutput
=
numOfOutput
;
pOperator
->
pTaskInfo
=
pTaskInfo
;
pOperator
->
pTaskInfo
=
pTaskInfo
;
pOperator
->
exec
=
doSortMerge
;
pOperator
->
exec
=
doSort
ed
Merge
;
pOperator
->
cleanupFn
=
destroyGlobalAggOperatorInfo
;
pOperator
->
cleanupFn
=
destroyGlobalAggOperatorInfo
;
appendDownstream
(
pOperator
,
downstream
);
appendDownstream
(
pOperator
,
downstream
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录