Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
c3e098d7
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看板
未验证
提交
c3e098d7
编写于
3月 24, 2022
作者:
X
Xiaoyu Wang
提交者:
GitHub
3月 24, 2022
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #10944 from taosdata/feature/3.0_wxy
reorganize physical plan code
上级
5f9e660f
c5bb4a51
变更
26
隐藏空白更改
内联
并排
Showing
26 changed file
with
1265 addition
and
725 deletion
+1265
-725
include/libs/nodes/nodes.h
include/libs/nodes/nodes.h
+2
-0
include/libs/nodes/plannodes.h
include/libs/nodes/plannodes.h
+13
-3
include/libs/nodes/querynodes.h
include/libs/nodes/querynodes.h
+1
-1
source/common/src/tmsg.c
source/common/src/tmsg.c
+3
-1
source/dnode/mgmt/test/vnode/vnode.cpp
source/dnode/mgmt/test/vnode/vnode.cpp
+2
-0
source/dnode/mnode/impl/src/mndStb.c
source/dnode/mnode/impl/src/mndStb.c
+3
-0
source/libs/executor/src/executorimpl.c
source/libs/executor/src/executorimpl.c
+1
-1
source/libs/nodes/src/nodesCloneFuncs.c
source/libs/nodes/src/nodesCloneFuncs.c
+5
-2
source/libs/nodes/src/nodesCodeFuncs.c
source/libs/nodes/src/nodesCodeFuncs.c
+140
-21
source/libs/nodes/src/nodesTraverseFuncs.c
source/libs/nodes/src/nodesTraverseFuncs.c
+7
-2
source/libs/nodes/src/nodesUtilFuncs.c
source/libs/nodes/src/nodesUtilFuncs.c
+15
-1
source/libs/parser/inc/parAst.h
source/libs/parser/inc/parAst.h
+1
-1
source/libs/parser/inc/sql.y
source/libs/parser/inc/sql.y
+1
-1
source/libs/parser/src/parAstCreater.c
source/libs/parser/src/parAstCreater.c
+2
-2
source/libs/parser/src/parTranslater.c
source/libs/parser/src/parTranslater.c
+23
-8
source/libs/parser/src/parUtil.c
source/libs/parser/src/parUtil.c
+1
-0
source/libs/parser/src/sql.c
source/libs/parser/src/sql.c
+184
-185
source/libs/parser/test/parserAstTest.cpp
source/libs/parser/test/parserAstTest.cpp
+73
-21
source/libs/planner/inc/planInt.h
source/libs/planner/inc/planInt.h
+4
-3
source/libs/planner/src/planLogicCreater.c
source/libs/planner/src/planLogicCreater.c
+38
-23
source/libs/planner/src/planOptimizer.c
source/libs/planner/src/planOptimizer.c
+20
-0
source/libs/planner/src/planPhysiCreater.c
source/libs/planner/src/planPhysiCreater.c
+416
-400
source/libs/planner/src/planScaleOut.c
source/libs/planner/src/planScaleOut.c
+203
-0
source/libs/planner/src/planSpliter.c
source/libs/planner/src/planSpliter.c
+50
-8
source/libs/planner/src/planner.c
source/libs/planner/src/planner.c
+15
-6
source/libs/planner/test/plannerTest.cpp
source/libs/planner/test/plannerTest.cpp
+42
-35
未找到文件。
include/libs/nodes/nodes.h
浏览文件 @
c3e098d7
...
@@ -135,6 +135,7 @@ typedef enum ENodeType {
...
@@ -135,6 +135,7 @@ typedef enum ENodeType {
QUERY_NODE_PHYSICAL_PLAN_EXCHANGE
,
QUERY_NODE_PHYSICAL_PLAN_EXCHANGE
,
QUERY_NODE_PHYSICAL_PLAN_SORT
,
QUERY_NODE_PHYSICAL_PLAN_SORT
,
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
,
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
,
QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW
,
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
,
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
,
QUERY_NODE_PHYSICAL_PLAN_INSERT
,
QUERY_NODE_PHYSICAL_PLAN_INSERT
,
QUERY_NODE_PHYSICAL_SUBPLAN
,
QUERY_NODE_PHYSICAL_SUBPLAN
,
...
@@ -169,6 +170,7 @@ void nodesDestroyNode(SNodeptr pNode);
...
@@ -169,6 +170,7 @@ void nodesDestroyNode(SNodeptr pNode);
SNodeList
*
nodesMakeList
();
SNodeList
*
nodesMakeList
();
int32_t
nodesListAppend
(
SNodeList
*
pList
,
SNodeptr
pNode
);
int32_t
nodesListAppend
(
SNodeList
*
pList
,
SNodeptr
pNode
);
int32_t
nodesListStrictAppend
(
SNodeList
*
pList
,
SNodeptr
pNode
);
int32_t
nodesListStrictAppend
(
SNodeList
*
pList
,
SNodeptr
pNode
);
int32_t
nodesListMakeAppend
(
SNodeList
**
pList
,
SNodeptr
pNode
);
int32_t
nodesListAppendList
(
SNodeList
*
pTarget
,
SNodeList
*
pSrc
);
int32_t
nodesListAppendList
(
SNodeList
*
pTarget
,
SNodeList
*
pSrc
);
int32_t
nodesListStrictAppendList
(
SNodeList
*
pTarget
,
SNodeList
*
pSrc
);
int32_t
nodesListStrictAppendList
(
SNodeList
*
pTarget
,
SNodeList
*
pSrc
);
SListCell
*
nodesListErase
(
SNodeList
*
pList
,
SListCell
*
pCell
);
SListCell
*
nodesListErase
(
SNodeList
*
pList
,
SListCell
*
pCell
);
...
...
include/libs/nodes/plannodes.h
浏览文件 @
c3e098d7
...
@@ -95,6 +95,7 @@ typedef struct SWindowLogicNode {
...
@@ -95,6 +95,7 @@ typedef struct SWindowLogicNode {
int8_t
intervalUnit
;
int8_t
intervalUnit
;
int8_t
slidingUnit
;
int8_t
slidingUnit
;
SFillNode
*
pFill
;
SFillNode
*
pFill
;
int64_t
sessionGap
;
}
SWindowLogicNode
;
}
SWindowLogicNode
;
typedef
enum
ESubplanType
{
typedef
enum
ESubplanType
{
...
@@ -110,7 +111,7 @@ typedef struct SSubplanId {
...
@@ -110,7 +111,7 @@ typedef struct SSubplanId {
int32_t
subplanId
;
int32_t
subplanId
;
}
SSubplanId
;
}
SSubplanId
;
typedef
struct
S
SubLogicP
lan
{
typedef
struct
S
LogicSubp
lan
{
ENodeType
type
;
ENodeType
type
;
SSubplanId
id
;
SSubplanId
id
;
SNodeList
*
pChildren
;
SNodeList
*
pChildren
;
...
@@ -120,7 +121,7 @@ typedef struct SSubLogicPlan {
...
@@ -120,7 +121,7 @@ typedef struct SSubLogicPlan {
SVgroupsInfo
*
pVgroupList
;
SVgroupsInfo
*
pVgroupList
;
int32_t
level
;
int32_t
level
;
int32_t
splitFlag
;
int32_t
splitFlag
;
}
S
SubLogicP
lan
;
}
S
LogicSubp
lan
;
typedef
struct
SQueryLogicPlan
{
typedef
struct
SQueryLogicPlan
{
ENodeType
type
;
ENodeType
type
;
...
@@ -213,10 +214,14 @@ typedef struct SExchangePhysiNode {
...
@@ -213,10 +214,14 @@ typedef struct SExchangePhysiNode {
SNodeList
*
pSrcEndPoints
;
// element is SDownstreamSource, scheduler fill by calling qSetSuplanExecutionNode
SNodeList
*
pSrcEndPoints
;
// element is SDownstreamSource, scheduler fill by calling qSetSuplanExecutionNode
}
SExchangePhysiNode
;
}
SExchangePhysiNode
;
typedef
struct
S
Interval
PhysiNode
{
typedef
struct
S
Winodw
PhysiNode
{
SPhysiNode
node
;
SPhysiNode
node
;
SNodeList
*
pExprs
;
// these are expression list of parameter expression of function
SNodeList
*
pExprs
;
// these are expression list of parameter expression of function
SNodeList
*
pFuncs
;
SNodeList
*
pFuncs
;
}
SWinodwPhysiNode
;
typedef
struct
SIntervalPhysiNode
{
SWinodwPhysiNode
window
;
int64_t
interval
;
int64_t
interval
;
int64_t
offset
;
int64_t
offset
;
int64_t
sliding
;
int64_t
sliding
;
...
@@ -225,6 +230,11 @@ typedef struct SIntervalPhysiNode {
...
@@ -225,6 +230,11 @@ typedef struct SIntervalPhysiNode {
SFillNode
*
pFill
;
SFillNode
*
pFill
;
}
SIntervalPhysiNode
;
}
SIntervalPhysiNode
;
typedef
struct
SSessionWinodwPhysiNode
{
SWinodwPhysiNode
window
;
int64_t
gap
;
}
SSessionWinodwPhysiNode
;
typedef
struct
SDataSinkNode
{
typedef
struct
SDataSinkNode
{
ENodeType
type
;
ENodeType
type
;
SDataBlockDescNode
*
pInputDataBlockDesc
;
SDataBlockDescNode
*
pInputDataBlockDesc
;
...
...
include/libs/nodes/querynodes.h
浏览文件 @
c3e098d7
...
@@ -191,8 +191,8 @@ typedef struct SStateWindowNode {
...
@@ -191,8 +191,8 @@ typedef struct SStateWindowNode {
typedef
struct
SSessionWindowNode
{
typedef
struct
SSessionWindowNode
{
ENodeType
type
;
// QUERY_NODE_SESSION_WINDOW
ENodeType
type
;
// QUERY_NODE_SESSION_WINDOW
int64_t
gap
;
// gap between two session window(in microseconds)
SNode
*
pCol
;
SNode
*
pCol
;
SNode
*
pGap
;
// gap between two session window(in microseconds)
}
SSessionWindowNode
;
}
SSessionWindowNode
;
typedef
struct
SIntervalWindowNode
{
typedef
struct
SIntervalWindowNode
{
...
...
source/common/src/tmsg.c
浏览文件 @
c3e098d7
...
@@ -287,6 +287,7 @@ int32_t tSerializeSVCreateTbReq(void **buf, SVCreateTbReq *pReq) {
...
@@ -287,6 +287,7 @@ int32_t tSerializeSVCreateTbReq(void **buf, SVCreateTbReq *pReq) {
int32_t
tlen
=
0
;
int32_t
tlen
=
0
;
tlen
+=
taosEncodeFixedI64
(
buf
,
pReq
->
ver
);
tlen
+=
taosEncodeFixedI64
(
buf
,
pReq
->
ver
);
tlen
+=
taosEncodeString
(
buf
,
pReq
->
dbFName
);
tlen
+=
taosEncodeString
(
buf
,
pReq
->
name
);
tlen
+=
taosEncodeString
(
buf
,
pReq
->
name
);
tlen
+=
taosEncodeFixedU32
(
buf
,
pReq
->
ttl
);
tlen
+=
taosEncodeFixedU32
(
buf
,
pReq
->
ttl
);
tlen
+=
taosEncodeFixedU32
(
buf
,
pReq
->
keep
);
tlen
+=
taosEncodeFixedU32
(
buf
,
pReq
->
keep
);
...
@@ -360,6 +361,7 @@ int32_t tSerializeSVCreateTbReq(void **buf, SVCreateTbReq *pReq) {
...
@@ -360,6 +361,7 @@ int32_t tSerializeSVCreateTbReq(void **buf, SVCreateTbReq *pReq) {
void
*
tDeserializeSVCreateTbReq
(
void
*
buf
,
SVCreateTbReq
*
pReq
)
{
void
*
tDeserializeSVCreateTbReq
(
void
*
buf
,
SVCreateTbReq
*
pReq
)
{
buf
=
taosDecodeFixedI64
(
buf
,
&
(
pReq
->
ver
));
buf
=
taosDecodeFixedI64
(
buf
,
&
(
pReq
->
ver
));
buf
=
taosDecodeString
(
buf
,
&
(
pReq
->
dbFName
));
buf
=
taosDecodeString
(
buf
,
&
(
pReq
->
name
));
buf
=
taosDecodeString
(
buf
,
&
(
pReq
->
name
));
buf
=
taosDecodeFixedU32
(
buf
,
&
(
pReq
->
ttl
));
buf
=
taosDecodeFixedU32
(
buf
,
&
(
pReq
->
ttl
));
buf
=
taosDecodeFixedU32
(
buf
,
&
(
pReq
->
keep
));
buf
=
taosDecodeFixedU32
(
buf
,
&
(
pReq
->
keep
));
...
@@ -478,7 +480,7 @@ void *tDeserializeSVCreateTbBatchReq(void *buf, SVCreateTbBatchReq *pReq) {
...
@@ -478,7 +480,7 @@ void *tDeserializeSVCreateTbBatchReq(void *buf, SVCreateTbBatchReq *pReq) {
buf
=
taosDecodeFixedU32
(
buf
,
&
nsize
);
buf
=
taosDecodeFixedU32
(
buf
,
&
nsize
);
pReq
->
pArray
=
taosArrayInit
(
nsize
,
sizeof
(
SVCreateTbReq
));
pReq
->
pArray
=
taosArrayInit
(
nsize
,
sizeof
(
SVCreateTbReq
));
for
(
size_t
i
=
0
;
i
<
nsize
;
i
++
)
{
for
(
size_t
i
=
0
;
i
<
nsize
;
i
++
)
{
SVCreateTbReq
req
;
SVCreateTbReq
req
=
{
0
}
;
buf
=
tDeserializeSVCreateTbReq
(
buf
,
&
req
);
buf
=
tDeserializeSVCreateTbReq
(
buf
,
&
req
);
taosArrayPush
(
pReq
->
pArray
,
&
req
);
taosArrayPush
(
pReq
->
pArray
,
&
req
);
}
}
...
...
source/dnode/mgmt/test/vnode/vnode.cpp
浏览文件 @
c3e098d7
...
@@ -158,6 +158,7 @@ TEST_F(DndTestVnode, 03_Create_Stb) {
...
@@ -158,6 +158,7 @@ TEST_F(DndTestVnode, 03_Create_Stb) {
for
(
int
i
=
0
;
i
<
1
;
++
i
)
{
for
(
int
i
=
0
;
i
<
1
;
++
i
)
{
SVCreateTbReq
req
=
{
0
};
SVCreateTbReq
req
=
{
0
};
req
.
ver
=
0
;
req
.
ver
=
0
;
req
.
dbFName
=
(
char
*
)
"1.db1"
;
req
.
name
=
(
char
*
)
"stb1"
;
req
.
name
=
(
char
*
)
"stb1"
;
req
.
ttl
=
0
;
req
.
ttl
=
0
;
req
.
keep
=
0
;
req
.
keep
=
0
;
...
@@ -229,6 +230,7 @@ TEST_F(DndTestVnode, 04_Alter_Stb) {
...
@@ -229,6 +230,7 @@ TEST_F(DndTestVnode, 04_Alter_Stb) {
for
(
int
i
=
0
;
i
<
1
;
++
i
)
{
for
(
int
i
=
0
;
i
<
1
;
++
i
)
{
SVCreateTbReq
req
=
{
0
};
SVCreateTbReq
req
=
{
0
};
req
.
ver
=
0
;
req
.
ver
=
0
;
req
.
dbFName
=
(
char
*
)
"1.db1"
;
req
.
name
=
(
char
*
)
"stb1"
;
req
.
name
=
(
char
*
)
"stb1"
;
req
.
ttl
=
0
;
req
.
ttl
=
0
;
req
.
keep
=
0
;
req
.
keep
=
0
;
...
...
source/dnode/mnode/impl/src/mndStb.c
浏览文件 @
c3e098d7
...
@@ -286,9 +286,12 @@ static SDbObj *mndAcquireDbByStb(SMnode *pMnode, const char *stbName) {
...
@@ -286,9 +286,12 @@ static SDbObj *mndAcquireDbByStb(SMnode *pMnode, const char *stbName) {
static
void
*
mndBuildVCreateStbReq
(
SMnode
*
pMnode
,
SVgObj
*
pVgroup
,
SStbObj
*
pStb
,
int32_t
*
pContLen
)
{
static
void
*
mndBuildVCreateStbReq
(
SMnode
*
pMnode
,
SVgObj
*
pVgroup
,
SStbObj
*
pStb
,
int32_t
*
pContLen
)
{
SName
name
=
{
0
};
SName
name
=
{
0
};
tNameFromString
(
&
name
,
pStb
->
name
,
T_NAME_ACCT
|
T_NAME_DB
|
T_NAME_TABLE
);
tNameFromString
(
&
name
,
pStb
->
name
,
T_NAME_ACCT
|
T_NAME_DB
|
T_NAME_TABLE
);
char
dbFName
[
TSDB_DB_FNAME_LEN
]
=
{
0
};
tNameGetFullDbName
(
&
name
,
dbFName
);
SVCreateTbReq
req
=
{
0
};
SVCreateTbReq
req
=
{
0
};
req
.
ver
=
0
;
req
.
ver
=
0
;
req
.
dbFName
=
dbFName
;
req
.
name
=
(
char
*
)
tNameGetTableName
(
&
name
);
req
.
name
=
(
char
*
)
tNameGetTableName
(
&
name
);
req
.
ttl
=
0
;
req
.
ttl
=
0
;
req
.
keep
=
0
;
req
.
keep
=
0
;
...
...
source/libs/executor/src/executorimpl.c
浏览文件 @
c3e098d7
...
@@ -8487,7 +8487,7 @@ SOperatorInfo* doCreateOperatorTreeNode(SPhysiNode* pPhyNode, SExecTaskInfo* pTa
...
@@ -8487,7 +8487,7 @@ SOperatorInfo* doCreateOperatorTreeNode(SPhysiNode* pPhyNode, SExecTaskInfo* pTa
SIntervalPhysiNode
*
pIntervalPhyNode
=
(
SIntervalPhysiNode
*
)
pPhyNode
;
SIntervalPhysiNode
*
pIntervalPhyNode
=
(
SIntervalPhysiNode
*
)
pPhyNode
;
int32_t
num
=
0
;
int32_t
num
=
0
;
SExprInfo
*
pExprInfo
=
createExprInfo
(
pIntervalPhyNode
->
pFuncs
,
NULL
,
&
num
);
SExprInfo
*
pExprInfo
=
createExprInfo
(
pIntervalPhyNode
->
window
.
pFuncs
,
NULL
,
&
num
);
SSDataBlock
*
pResBlock
=
createOutputBuf_rv1
(
pPhyNode
->
pOutputDataBlockDesc
);
SSDataBlock
*
pResBlock
=
createOutputBuf_rv1
(
pPhyNode
->
pOutputDataBlockDesc
);
SInterval
interval
=
{.
interval
=
pIntervalPhyNode
->
interval
,
.
sliding
=
pIntervalPhyNode
->
sliding
,
SInterval
interval
=
{.
interval
=
pIntervalPhyNode
->
interval
,
.
sliding
=
pIntervalPhyNode
->
sliding
,
...
...
source/libs/nodes/src/nodesCloneFuncs.c
浏览文件 @
c3e098d7
...
@@ -272,11 +272,14 @@ static SNode* logicWindowCopy(const SWindowLogicNode* pSrc, SWindowLogicNode* pD
...
@@ -272,11 +272,14 @@ static SNode* logicWindowCopy(const SWindowLogicNode* pSrc, SWindowLogicNode* pD
COPY_SCALAR_FIELD
(
interval
);
COPY_SCALAR_FIELD
(
interval
);
COPY_SCALAR_FIELD
(
offset
);
COPY_SCALAR_FIELD
(
offset
);
COPY_SCALAR_FIELD
(
sliding
);
COPY_SCALAR_FIELD
(
sliding
);
COPY_SCALAR_FIELD
(
intervalUnit
);
COPY_SCALAR_FIELD
(
slidingUnit
);
CLONE_NODE_FIELD
(
pFill
);
CLONE_NODE_FIELD
(
pFill
);
COPY_SCALAR_FIELD
(
sessionGap
);
return
(
SNode
*
)
pDst
;
return
(
SNode
*
)
pDst
;
}
}
static
SNode
*
logicSubplanCopy
(
const
S
SubLogicPlan
*
pSrc
,
SSubLogicP
lan
*
pDst
)
{
static
SNode
*
logicSubplanCopy
(
const
S
LogicSubplan
*
pSrc
,
SLogicSubp
lan
*
pDst
)
{
CLONE_NODE_FIELD
(
pNode
);
CLONE_NODE_FIELD
(
pNode
);
COPY_SCALAR_FIELD
(
subplanType
);
COPY_SCALAR_FIELD
(
subplanType
);
return
(
SNode
*
)
pDst
;
return
(
SNode
*
)
pDst
;
...
@@ -358,7 +361,7 @@ SNodeptr nodesCloneNode(const SNodeptr pNode) {
...
@@ -358,7 +361,7 @@ SNodeptr nodesCloneNode(const SNodeptr pNode) {
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
return
logicWindowCopy
((
const
SWindowLogicNode
*
)
pNode
,
(
SWindowLogicNode
*
)
pDst
);
return
logicWindowCopy
((
const
SWindowLogicNode
*
)
pNode
,
(
SWindowLogicNode
*
)
pDst
);
case
QUERY_NODE_LOGIC_SUBPLAN
:
case
QUERY_NODE_LOGIC_SUBPLAN
:
return
logicSubplanCopy
((
const
S
SubLogicPlan
*
)
pNode
,
(
SSubLogicP
lan
*
)
pDst
);
return
logicSubplanCopy
((
const
S
LogicSubplan
*
)
pNode
,
(
SLogicSubp
lan
*
)
pDst
);
default:
default:
break
;
break
;
}
}
...
...
source/libs/nodes/src/nodesCodeFuncs.c
浏览文件 @
c3e098d7
...
@@ -70,6 +70,14 @@ const char* nodesNodeName(ENodeType type) {
...
@@ -70,6 +70,14 @@ const char* nodesNodeName(ENodeType type) {
return
"SlotDesc"
;
return
"SlotDesc"
;
case
QUERY_NODE_COLUMN_DEF
:
case
QUERY_NODE_COLUMN_DEF
:
return
"ColumnDef"
;
return
"ColumnDef"
;
case
QUERY_NODE_DOWNSTREAM_SOURCE
:
return
"DownstreamSource"
;
case
QUERY_NODE_DATABASE_OPTIONS
:
return
"DatabaseOptions"
;
case
QUERY_NODE_TABLE_OPTIONS
:
return
"TableOptions"
;
case
QUERY_NODE_INDEX_OPTIONS
:
return
"IndexOptions"
;
case
QUERY_NODE_SET_OPERATOR
:
case
QUERY_NODE_SET_OPERATOR
:
return
"SetOperator"
;
return
"SetOperator"
;
case
QUERY_NODE_SELECT_STMT
:
case
QUERY_NODE_SELECT_STMT
:
...
@@ -78,16 +86,76 @@ const char* nodesNodeName(ENodeType type) {
...
@@ -78,16 +86,76 @@ const char* nodesNodeName(ENodeType type) {
return
"VnodeModifStmt"
;
return
"VnodeModifStmt"
;
case
QUERY_NODE_CREATE_DATABASE_STMT
:
case
QUERY_NODE_CREATE_DATABASE_STMT
:
return
"CreateDatabaseStmt"
;
return
"CreateDatabaseStmt"
;
case
QUERY_NODE_DROP_DATABASE_STMT
:
return
"DropDatabaseStmt"
;
case
QUERY_NODE_ALTER_DATABASE_STMT
:
return
"AlterDatabaseStmt"
;
case
QUERY_NODE_CREATE_TABLE_STMT
:
case
QUERY_NODE_CREATE_TABLE_STMT
:
return
"CreateTableStmt"
;
return
"CreateTableStmt"
;
case
QUERY_NODE_CREATE_SUBTABLE_CLAUSE
:
return
"CreateSubtableClause"
;
case
QUERY_NODE_CREATE_MULTI_TABLE_STMT
:
return
"CreateMultiTableStmt"
;
case
QUERY_NODE_DROP_TABLE_CLAUSE
:
return
"DropTableClause"
;
case
QUERY_NODE_DROP_TABLE_STMT
:
return
"DropTableStmt"
;
case
QUERY_NODE_DROP_SUPER_TABLE_STMT
:
return
"DropSuperTableStmt"
;
case
QUERY_NODE_ALTER_TABLE_STMT
:
return
"AlterTableStmt"
;
case
QUERY_NODE_CREATE_USER_STMT
:
return
"CreateUserStmt"
;
case
QUERY_NODE_ALTER_USER_STMT
:
return
"AlterUserStmt"
;
case
QUERY_NODE_DROP_USER_STMT
:
return
"DropUserStmt"
;
case
QUERY_NODE_USE_DATABASE_STMT
:
case
QUERY_NODE_USE_DATABASE_STMT
:
return
"UseDatabaseStmt"
;
return
"UseDatabaseStmt"
;
case
QUERY_NODE_CREATE_DNODE_STMT
:
return
"CreateDnodeStmt"
;
case
QUERY_NODE_DROP_DNODE_STMT
:
return
"DropDnodeStmt"
;
case
QUERY_NODE_ALTER_DNODE_STMT
:
return
"AlterDnodeStmt"
;
case
QUERY_NODE_CREATE_INDEX_STMT
:
return
"CreateIndexStmt"
;
case
QUERY_NODE_DROP_INDEX_STMT
:
return
"DropIndexStmt"
;
case
QUERY_NODE_CREATE_QNODE_STMT
:
return
"CreateQnodeStmt"
;
case
QUERY_NODE_DROP_QNODE_STMT
:
return
"DropQnodeStmt"
;
case
QUERY_NODE_CREATE_TOPIC_STMT
:
return
"CreateTopicStmt"
;
case
QUERY_NODE_DROP_TOPIC_STMT
:
return
"DropTopicStmt"
;
case
QUERY_NODE_ALTER_LOCAL_STMT
:
return
"AlterLocalStmt"
;
case
QUERY_NODE_SHOW_DATABASES_STMT
:
case
QUERY_NODE_SHOW_DATABASES_STMT
:
return
"ShowDatabaseStmt"
;
return
"ShowDatabaseStmt"
;
case
QUERY_NODE_SHOW_TABLES_STMT
:
case
QUERY_NODE_SHOW_TABLES_STMT
:
return
"ShowTablesStmt"
;
return
"ShowTablesStmt"
;
case
QUERY_NODE_CREATE_TOPIC_STMT
:
case
QUERY_NODE_SHOW_STABLES_STMT
:
return
"CreateTopicStmt"
;
return
"ShowStablesStmt"
;
case
QUERY_NODE_SHOW_USERS_STMT
:
return
"ShowUsersStmt"
;
case
QUERY_NODE_SHOW_DNODES_STMT
:
return
"ShowDnodesStmt"
;
case
QUERY_NODE_SHOW_VGROUPS_STMT
:
return
"ShowVgroupsStmt"
;
case
QUERY_NODE_SHOW_MNODES_STMT
:
return
"ShowMnodesStmt"
;
case
QUERY_NODE_SHOW_MODULES_STMT
:
return
"ShowModulesStmt"
;
case
QUERY_NODE_SHOW_QNODES_STMT
:
return
"ShowQnodesStmt"
;
case
QUERY_NODE_SHOW_FUNCTIONS_STMT
:
return
"ShowFunctionsStmt"
;
case
QUERY_NODE_SHOW_INDEXES_STMT
:
return
"ShowIndexesStmt"
;
case
QUERY_NODE_SHOW_STREAMS_STMT
:
return
"ShowStreamsStmt"
;
case
QUERY_NODE_LOGIC_PLAN_SCAN
:
case
QUERY_NODE_LOGIC_PLAN_SCAN
:
return
"LogicScan"
;
return
"LogicScan"
;
case
QUERY_NODE_LOGIC_PLAN_JOIN
:
case
QUERY_NODE_LOGIC_PLAN_JOIN
:
...
@@ -98,6 +166,10 @@ const char* nodesNodeName(ENodeType type) {
...
@@ -98,6 +166,10 @@ const char* nodesNodeName(ENodeType type) {
return
"LogicProject"
;
return
"LogicProject"
;
case
QUERY_NODE_LOGIC_PLAN_VNODE_MODIF
:
case
QUERY_NODE_LOGIC_PLAN_VNODE_MODIF
:
return
"LogicVnodeModif"
;
return
"LogicVnodeModif"
;
case
QUERY_NODE_LOGIC_PLAN_EXCHANGE
:
return
"LogicExchange"
;
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
return
"LogicWindow"
;
case
QUERY_NODE_LOGIC_SUBPLAN
:
case
QUERY_NODE_LOGIC_SUBPLAN
:
return
"LogicSubplan"
;
return
"LogicSubplan"
;
case
QUERY_NODE_LOGIC_PLAN
:
case
QUERY_NODE_LOGIC_PLAN
:
...
@@ -124,6 +196,8 @@ const char* nodesNodeName(ENodeType type) {
...
@@ -124,6 +196,8 @@ const char* nodesNodeName(ENodeType type) {
return
"PhysiSort"
;
return
"PhysiSort"
;
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
return
"PhysiInterval"
;
return
"PhysiInterval"
;
case
QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW
:
return
"PhysiSessionWindow"
;
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
return
"PhysiDispatch"
;
return
"PhysiDispatch"
;
case
QUERY_NODE_PHYSICAL_PLAN_INSERT
:
case
QUERY_NODE_PHYSICAL_PLAN_INSERT
:
...
@@ -846,8 +920,37 @@ static int32_t jsonToPhysiExchangeNode(const SJson* pJson, void* pObj) {
...
@@ -846,8 +920,37 @@ static int32_t jsonToPhysiExchangeNode(const SJson* pJson, void* pObj) {
return
code
;
return
code
;
}
}
static
const
char
*
jkIntervalPhysiPlanExprs
=
"Exprs"
;
static
const
char
*
jkWindowPhysiPlanExprs
=
"Exprs"
;
static
const
char
*
jkIntervalPhysiPlanFuncs
=
"Funcs"
;
static
const
char
*
jkWindowPhysiPlanFuncs
=
"Funcs"
;
static
int32_t
physiWindowNodeToJson
(
const
void
*
pObj
,
SJson
*
pJson
)
{
const
SWinodwPhysiNode
*
pNode
=
(
const
SWinodwPhysiNode
*
)
pObj
;
int32_t
code
=
physicPlanNodeToJson
(
pObj
,
pJson
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodeListToJson
(
pJson
,
jkWindowPhysiPlanExprs
,
pNode
->
pExprs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodeListToJson
(
pJson
,
jkWindowPhysiPlanFuncs
,
pNode
->
pFuncs
);
}
return
code
;
}
static
int32_t
jsonToPhysiWindowNode
(
const
SJson
*
pJson
,
void
*
pObj
)
{
SWinodwPhysiNode
*
pNode
=
(
SWinodwPhysiNode
*
)
pObj
;
int32_t
code
=
jsonToPhysicPlanNode
(
pJson
,
pObj
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
jsonToNodeList
(
pJson
,
jkWindowPhysiPlanExprs
,
&
pNode
->
pExprs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
jsonToNodeList
(
pJson
,
jkWindowPhysiPlanFuncs
,
&
pNode
->
pFuncs
);
}
return
code
;
}
static
const
char
*
jkIntervalPhysiPlanInterval
=
"Interval"
;
static
const
char
*
jkIntervalPhysiPlanInterval
=
"Interval"
;
static
const
char
*
jkIntervalPhysiPlanOffset
=
"Offset"
;
static
const
char
*
jkIntervalPhysiPlanOffset
=
"Offset"
;
static
const
char
*
jkIntervalPhysiPlanSliding
=
"Sliding"
;
static
const
char
*
jkIntervalPhysiPlanSliding
=
"Sliding"
;
...
@@ -858,13 +961,7 @@ static const char* jkIntervalPhysiPlanFill = "Fill";
...
@@ -858,13 +961,7 @@ static const char* jkIntervalPhysiPlanFill = "Fill";
static
int32_t
physiIntervalNodeToJson
(
const
void
*
pObj
,
SJson
*
pJson
)
{
static
int32_t
physiIntervalNodeToJson
(
const
void
*
pObj
,
SJson
*
pJson
)
{
const
SIntervalPhysiNode
*
pNode
=
(
const
SIntervalPhysiNode
*
)
pObj
;
const
SIntervalPhysiNode
*
pNode
=
(
const
SIntervalPhysiNode
*
)
pObj
;
int32_t
code
=
physicPlanNodeToJson
(
pObj
,
pJson
);
int32_t
code
=
physiWindowNodeToJson
(
pObj
,
pJson
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodeListToJson
(
pJson
,
jkIntervalPhysiPlanExprs
,
pNode
->
pExprs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodeListToJson
(
pJson
,
jkIntervalPhysiPlanFuncs
,
pNode
->
pFuncs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
tjsonAddIntegerToObject
(
pJson
,
jkIntervalPhysiPlanInterval
,
pNode
->
interval
);
code
=
tjsonAddIntegerToObject
(
pJson
,
jkIntervalPhysiPlanInterval
,
pNode
->
interval
);
}
}
...
@@ -890,13 +987,7 @@ static int32_t physiIntervalNodeToJson(const void* pObj, SJson* pJson) {
...
@@ -890,13 +987,7 @@ static int32_t physiIntervalNodeToJson(const void* pObj, SJson* pJson) {
static
int32_t
jsonToPhysiIntervalNode
(
const
SJson
*
pJson
,
void
*
pObj
)
{
static
int32_t
jsonToPhysiIntervalNode
(
const
SJson
*
pJson
,
void
*
pObj
)
{
SIntervalPhysiNode
*
pNode
=
(
SIntervalPhysiNode
*
)
pObj
;
SIntervalPhysiNode
*
pNode
=
(
SIntervalPhysiNode
*
)
pObj
;
int32_t
code
=
jsonToPhysicPlanNode
(
pJson
,
pObj
);
int32_t
code
=
jsonToPhysiWindowNode
(
pJson
,
pObj
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
jsonToNodeList
(
pJson
,
jkIntervalPhysiPlanExprs
,
&
pNode
->
pExprs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
jsonToNodeList
(
pJson
,
jkIntervalPhysiPlanFuncs
,
&
pNode
->
pFuncs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
tjsonGetBigIntValue
(
pJson
,
jkIntervalPhysiPlanInterval
,
&
pNode
->
interval
);
code
=
tjsonGetBigIntValue
(
pJson
,
jkIntervalPhysiPlanInterval
,
&
pNode
->
interval
);
}
}
...
@@ -919,6 +1010,30 @@ static int32_t jsonToPhysiIntervalNode(const SJson* pJson, void* pObj) {
...
@@ -919,6 +1010,30 @@ static int32_t jsonToPhysiIntervalNode(const SJson* pJson, void* pObj) {
return
code
;
return
code
;
}
}
static
const
char
*
jkSessionWindowPhysiPlanGap
=
"Gap"
;
static
int32_t
physiSessionWindowNodeToJson
(
const
void
*
pObj
,
SJson
*
pJson
)
{
const
SSessionWinodwPhysiNode
*
pNode
=
(
const
SSessionWinodwPhysiNode
*
)
pObj
;
int32_t
code
=
physiWindowNodeToJson
(
pObj
,
pJson
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
tjsonAddIntegerToObject
(
pJson
,
jkSessionWindowPhysiPlanGap
,
pNode
->
gap
);
}
return
code
;
}
static
int32_t
jsonToPhysiSessionWindowNode
(
const
SJson
*
pJson
,
void
*
pObj
)
{
SSessionWinodwPhysiNode
*
pNode
=
(
SSessionWinodwPhysiNode
*
)
pObj
;
int32_t
code
=
jsonToPhysiWindowNode
(
pJson
,
pObj
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
tjsonGetNumberValue
(
pJson
,
jkSessionWindowPhysiPlanGap
,
pNode
->
gap
);
}
return
code
;
}
static
const
char
*
jkDataSinkInputDataBlockDesc
=
"InputDataBlockDesc"
;
static
const
char
*
jkDataSinkInputDataBlockDesc
=
"InputDataBlockDesc"
;
static
int32_t
physicDataSinkNodeToJson
(
const
void
*
pObj
,
SJson
*
pJson
)
{
static
int32_t
physicDataSinkNodeToJson
(
const
void
*
pObj
,
SJson
*
pJson
)
{
...
@@ -2066,6 +2181,8 @@ static int32_t specificNodeToJson(const void* pObj, SJson* pJson) {
...
@@ -2066,6 +2181,8 @@ static int32_t specificNodeToJson(const void* pObj, SJson* pJson) {
break
;
break
;
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
return
physiIntervalNodeToJson
(
pObj
,
pJson
);
return
physiIntervalNodeToJson
(
pObj
,
pJson
);
case
QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW
:
return
physiSessionWindowNodeToJson
(
pObj
,
pJson
);
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
return
physiDispatchNodeToJson
(
pObj
,
pJson
);
return
physiDispatchNodeToJson
(
pObj
,
pJson
);
case
QUERY_NODE_PHYSICAL_PLAN_INSERT
:
case
QUERY_NODE_PHYSICAL_PLAN_INSERT
:
...
@@ -2075,7 +2192,7 @@ static int32_t specificNodeToJson(const void* pObj, SJson* pJson) {
...
@@ -2075,7 +2192,7 @@ static int32_t specificNodeToJson(const void* pObj, SJson* pJson) {
case
QUERY_NODE_PHYSICAL_PLAN
:
case
QUERY_NODE_PHYSICAL_PLAN
:
return
planToJson
(
pObj
,
pJson
);
return
planToJson
(
pObj
,
pJson
);
default:
default:
assert
(
0
);
//
assert(0);
break
;
break
;
}
}
nodesWarn
(
"specificNodeToJson unknown node = %s"
,
nodesNodeName
(
nodeType
(
pObj
)));
nodesWarn
(
"specificNodeToJson unknown node = %s"
,
nodesNodeName
(
nodeType
(
pObj
)));
...
@@ -2149,14 +2266,16 @@ static int32_t jsonToSpecificNode(const SJson* pJson, void* pObj) {
...
@@ -2149,14 +2266,16 @@ static int32_t jsonToSpecificNode(const SJson* pJson, void* pObj) {
return
jsonToPhysiAggNode
(
pJson
,
pObj
);
return
jsonToPhysiAggNode
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_PLAN_EXCHANGE
:
case
QUERY_NODE_PHYSICAL_PLAN_EXCHANGE
:
return
jsonToPhysiExchangeNode
(
pJson
,
pObj
);
return
jsonToPhysiExchangeNode
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
return
jsonToPhysiIntervalNode
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW
:
return
jsonToPhysiSessionWindowNode
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
return
jsonToPhysiDispatchNode
(
pJson
,
pObj
);
return
jsonToPhysiDispatchNode
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_SUBPLAN
:
case
QUERY_NODE_PHYSICAL_SUBPLAN
:
return
jsonToSubplan
(
pJson
,
pObj
);
return
jsonToSubplan
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_PLAN
:
case
QUERY_NODE_PHYSICAL_PLAN
:
return
jsonToPlan
(
pJson
,
pObj
);
return
jsonToPlan
(
pJson
,
pObj
);
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
return
jsonToPhysiIntervalNode
(
pJson
,
pObj
);
default:
default:
assert
(
0
);
assert
(
0
);
break
;
break
;
...
...
source/libs/nodes/src/nodesTraverseFuncs.c
浏览文件 @
c3e098d7
...
@@ -79,9 +79,14 @@ static EDealRes walkNode(SNode* pNode, ETraversalOrder order, FNodeWalker walker
...
@@ -79,9 +79,14 @@ static EDealRes walkNode(SNode* pNode, ETraversalOrder order, FNodeWalker walker
case
QUERY_NODE_STATE_WINDOW
:
case
QUERY_NODE_STATE_WINDOW
:
res
=
walkNode
(((
SStateWindowNode
*
)
pNode
)
->
pCol
,
order
,
walker
,
pContext
);
res
=
walkNode
(((
SStateWindowNode
*
)
pNode
)
->
pCol
,
order
,
walker
,
pContext
);
break
;
break
;
case
QUERY_NODE_SESSION_WINDOW
:
case
QUERY_NODE_SESSION_WINDOW
:
{
res
=
walkNode
(((
SSessionWindowNode
*
)
pNode
)
->
pCol
,
order
,
walker
,
pContext
);
SSessionWindowNode
*
pSession
=
(
SSessionWindowNode
*
)
pNode
;
res
=
walkNode
(
pSession
->
pCol
,
order
,
walker
,
pContext
);
if
(
DEAL_RES_ERROR
!=
res
)
{
res
=
walkNode
(
pSession
->
pGap
,
order
,
walker
,
pContext
);
}
break
;
break
;
}
case
QUERY_NODE_INTERVAL_WINDOW
:
{
case
QUERY_NODE_INTERVAL_WINDOW
:
{
SIntervalWindowNode
*
pInterval
=
(
SIntervalWindowNode
*
)
pNode
;
SIntervalWindowNode
*
pInterval
=
(
SIntervalWindowNode
*
)
pNode
;
res
=
walkNode
(
pInterval
->
pInterval
,
order
,
walker
,
pContext
);
res
=
walkNode
(
pInterval
->
pInterval
,
order
,
walker
,
pContext
);
...
...
source/libs/nodes/src/nodesUtilFuncs.c
浏览文件 @
c3e098d7
...
@@ -160,7 +160,7 @@ SNodeptr nodesMakeNode(ENodeType type) {
...
@@ -160,7 +160,7 @@ SNodeptr nodesMakeNode(ENodeType type) {
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
return
makeNode
(
type
,
sizeof
(
SWindowLogicNode
));
return
makeNode
(
type
,
sizeof
(
SWindowLogicNode
));
case
QUERY_NODE_LOGIC_SUBPLAN
:
case
QUERY_NODE_LOGIC_SUBPLAN
:
return
makeNode
(
type
,
sizeof
(
S
SubLogicP
lan
));
return
makeNode
(
type
,
sizeof
(
S
LogicSubp
lan
));
case
QUERY_NODE_LOGIC_PLAN
:
case
QUERY_NODE_LOGIC_PLAN
:
return
makeNode
(
type
,
sizeof
(
SQueryLogicPlan
));
return
makeNode
(
type
,
sizeof
(
SQueryLogicPlan
));
case
QUERY_NODE_PHYSICAL_PLAN_TAG_SCAN
:
case
QUERY_NODE_PHYSICAL_PLAN_TAG_SCAN
:
...
@@ -185,6 +185,8 @@ SNodeptr nodesMakeNode(ENodeType type) {
...
@@ -185,6 +185,8 @@ SNodeptr nodesMakeNode(ENodeType type) {
return
makeNode
(
type
,
sizeof
(
SNode
));
return
makeNode
(
type
,
sizeof
(
SNode
));
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
case
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
:
return
makeNode
(
type
,
sizeof
(
SIntervalPhysiNode
));
return
makeNode
(
type
,
sizeof
(
SIntervalPhysiNode
));
case
QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW
:
return
makeNode
(
type
,
sizeof
(
SSessionWinodwPhysiNode
));
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
case
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
:
return
makeNode
(
type
,
sizeof
(
SDataDispatcherNode
));
return
makeNode
(
type
,
sizeof
(
SDataDispatcherNode
));
case
QUERY_NODE_PHYSICAL_PLAN_INSERT
:
case
QUERY_NODE_PHYSICAL_PLAN_INSERT
:
...
@@ -332,6 +334,7 @@ int32_t nodesListAppend(SNodeList* pList, SNodeptr pNode) {
...
@@ -332,6 +334,7 @@ int32_t nodesListAppend(SNodeList* pList, SNodeptr pNode) {
int32_t
nodesListStrictAppend
(
SNodeList
*
pList
,
SNodeptr
pNode
)
{
int32_t
nodesListStrictAppend
(
SNodeList
*
pList
,
SNodeptr
pNode
)
{
if
(
NULL
==
pNode
)
{
if
(
NULL
==
pNode
)
{
terrno
=
TSDB_CODE_OUT_OF_MEMORY
;
return
TSDB_CODE_OUT_OF_MEMORY
;
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
int32_t
code
=
nodesListAppend
(
pList
,
pNode
);
int32_t
code
=
nodesListAppend
(
pList
,
pNode
);
...
@@ -341,6 +344,17 @@ int32_t nodesListStrictAppend(SNodeList* pList, SNodeptr pNode) {
...
@@ -341,6 +344,17 @@ int32_t nodesListStrictAppend(SNodeList* pList, SNodeptr pNode) {
return
code
;
return
code
;
}
}
int32_t
nodesListMakeAppend
(
SNodeList
**
pList
,
SNodeptr
pNode
)
{
if
(
NULL
==
*
pList
)
{
*
pList
=
nodesMakeList
();
if
(
NULL
==
*
pList
)
{
terrno
=
TSDB_CODE_OUT_OF_MEMORY
;
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
return
nodesListAppend
(
*
pList
,
pNode
);
}
int32_t
nodesListAppendList
(
SNodeList
*
pTarget
,
SNodeList
*
pSrc
)
{
int32_t
nodesListAppendList
(
SNodeList
*
pTarget
,
SNodeList
*
pSrc
)
{
if
(
NULL
==
pTarget
||
NULL
==
pSrc
)
{
if
(
NULL
==
pTarget
||
NULL
==
pSrc
)
{
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
...
...
source/libs/parser/inc/parAst.h
浏览文件 @
c3e098d7
...
@@ -100,7 +100,7 @@ SNode* createTempTableNode(SAstCreateContext* pCxt, SNode* pSubquery, const STok
...
@@ -100,7 +100,7 @@ SNode* createTempTableNode(SAstCreateContext* pCxt, SNode* pSubquery, const STok
SNode
*
createJoinTableNode
(
SAstCreateContext
*
pCxt
,
EJoinType
type
,
SNode
*
pLeft
,
SNode
*
pRight
,
SNode
*
pJoinCond
);
SNode
*
createJoinTableNode
(
SAstCreateContext
*
pCxt
,
EJoinType
type
,
SNode
*
pLeft
,
SNode
*
pRight
,
SNode
*
pJoinCond
);
SNode
*
createLimitNode
(
SAstCreateContext
*
pCxt
,
const
SToken
*
pLimit
,
const
SToken
*
pOffset
);
SNode
*
createLimitNode
(
SAstCreateContext
*
pCxt
,
const
SToken
*
pLimit
,
const
SToken
*
pOffset
);
SNode
*
createOrderByExprNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pExpr
,
EOrder
order
,
ENullOrder
nullOrder
);
SNode
*
createOrderByExprNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pExpr
,
EOrder
order
,
ENullOrder
nullOrder
);
SNode
*
createSessionWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pCol
,
const
SToken
*
pVal
);
SNode
*
createSessionWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pCol
,
SNode
*
pGap
);
SNode
*
createStateWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pCol
);
SNode
*
createStateWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pCol
);
SNode
*
createIntervalWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pInterval
,
SNode
*
pOffset
,
SNode
*
pSliding
,
SNode
*
pFill
);
SNode
*
createIntervalWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pInterval
,
SNode
*
pOffset
,
SNode
*
pSliding
,
SNode
*
pFill
);
SNode
*
createFillNode
(
SAstCreateContext
*
pCxt
,
EFillMode
mode
,
SNode
*
pValues
);
SNode
*
createFillNode
(
SAstCreateContext
*
pCxt
,
EFillMode
mode
,
SNode
*
pValues
);
...
...
source/libs/parser/inc/sql.y
浏览文件 @
c3e098d7
...
@@ -624,7 +624,7 @@ partition_by_clause_opt(A) ::= PARTITION BY expression_list(B).
...
@@ -624,7 +624,7 @@ partition_by_clause_opt(A) ::= PARTITION BY expression_list(B).
twindow_clause_opt(A) ::= . { A = NULL; }
twindow_clause_opt(A) ::= . { A = NULL; }
twindow_clause_opt(A) ::=
twindow_clause_opt(A) ::=
SESSION NK_LP column_reference(B) NK_COMMA
NK_INTEGER(C) NK_RP. { A = createSessionWindowNode(pCxt, releaseRawExprNode(pCxt, B), &C
); }
SESSION NK_LP column_reference(B) NK_COMMA
duration_literal(C) NK_RP. { A = createSessionWindowNode(pCxt, releaseRawExprNode(pCxt, B), releaseRawExprNode(pCxt, C)
); }
twindow_clause_opt(A) ::= STATE_WINDOW NK_LP column_reference(B) NK_RP. { A = createStateWindowNode(pCxt, releaseRawExprNode(pCxt, B)); }
twindow_clause_opt(A) ::= STATE_WINDOW NK_LP column_reference(B) NK_RP. { A = createStateWindowNode(pCxt, releaseRawExprNode(pCxt, B)); }
twindow_clause_opt(A) ::=
twindow_clause_opt(A) ::=
INTERVAL NK_LP duration_literal(B) NK_RP sliding_opt(C) fill_opt(D). { A = createIntervalWindowNode(pCxt, releaseRawExprNode(pCxt, B), NULL, C, D); }
INTERVAL NK_LP duration_literal(B) NK_RP sliding_opt(C) fill_opt(D). { A = createIntervalWindowNode(pCxt, releaseRawExprNode(pCxt, B), NULL, C, D); }
...
...
source/libs/parser/src/parAstCreater.c
浏览文件 @
c3e098d7
...
@@ -679,11 +679,11 @@ SNode* createOrderByExprNode(SAstCreateContext* pCxt, SNode* pExpr, EOrder order
...
@@ -679,11 +679,11 @@ SNode* createOrderByExprNode(SAstCreateContext* pCxt, SNode* pExpr, EOrder order
return
(
SNode
*
)
orderByExpr
;
return
(
SNode
*
)
orderByExpr
;
}
}
SNode
*
createSessionWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pCol
,
const
SToken
*
pVal
)
{
SNode
*
createSessionWindowNode
(
SAstCreateContext
*
pCxt
,
SNode
*
pCol
,
SNode
*
pGap
)
{
SSessionWindowNode
*
session
=
(
SSessionWindowNode
*
)
nodesMakeNode
(
QUERY_NODE_SESSION_WINDOW
);
SSessionWindowNode
*
session
=
(
SSessionWindowNode
*
)
nodesMakeNode
(
QUERY_NODE_SESSION_WINDOW
);
CHECK_OUT_OF_MEM
(
session
);
CHECK_OUT_OF_MEM
(
session
);
session
->
pCol
=
pCol
;
session
->
pCol
=
pCol
;
// session->gap = getInteger(pVal)
;
session
->
pGap
=
pGap
;
return
(
SNode
*
)
session
;
return
(
SNode
*
)
session
;
}
}
...
...
source/libs/parser/src/parTranslater.c
浏览文件 @
c3e098d7
...
@@ -1870,14 +1870,21 @@ static void toSchema(const SColumnDefNode* pCol, int32_t colId, SSchema* pSchema
...
@@ -1870,14 +1870,21 @@ static void toSchema(const SColumnDefNode* pCol, int32_t colId, SSchema* pSchema
}
}
static
void
destroyCreateTbReq
(
SVCreateTbReq
*
pReq
)
{
static
void
destroyCreateTbReq
(
SVCreateTbReq
*
pReq
)
{
tfree
(
pReq
->
dbFName
);
tfree
(
pReq
->
name
);
tfree
(
pReq
->
name
);
tfree
(
pReq
->
ntbCfg
.
pSchema
);
tfree
(
pReq
->
ntbCfg
.
pSchema
);
}
}
static
int32_t
buildNormalTableBatchReq
(
static
int32_t
buildNormalTableBatchReq
(
int32_t
acctId
,
const
char
*
pDbName
,
const
char
*
pTableName
,
const
char
*
pDbName
,
const
char
*
pTableName
,
const
SNodeList
*
pColumns
,
const
SVgroupInfo
*
pVgroupInfo
,
SVgroupTablesBatch
*
pBatch
)
{
const
SNodeList
*
pColumns
,
const
SVgroupInfo
*
pVgroupInfo
,
SVgroupTablesBatch
*
pBatch
)
{
char
dbFName
[
TSDB_DB_FNAME_LEN
]
=
{
0
};
SName
name
=
{
.
type
=
TSDB_DB_NAME_T
,
.
acctId
=
acctId
};
strcpy
(
name
.
dbname
,
pDbName
);
tNameGetFullDbName
(
&
name
,
dbFName
);
SVCreateTbReq
req
=
{
0
};
SVCreateTbReq
req
=
{
0
};
req
.
type
=
TD_NORMAL_TABLE
;
req
.
type
=
TD_NORMAL_TABLE
;
req
.
dbFName
=
strdup
(
dbFName
);
req
.
name
=
strdup
(
pTableName
);
req
.
name
=
strdup
(
pTableName
);
req
.
ntbCfg
.
nCols
=
LIST_LENGTH
(
pColumns
);
req
.
ntbCfg
.
nCols
=
LIST_LENGTH
(
pColumns
);
req
.
ntbCfg
.
pSchema
=
calloc
(
req
.
ntbCfg
.
nCols
,
sizeof
(
SSchema
));
req
.
ntbCfg
.
pSchema
=
calloc
(
req
.
ntbCfg
.
nCols
,
sizeof
(
SSchema
));
...
@@ -1904,7 +1911,7 @@ static int32_t buildNormalTableBatchReq(
...
@@ -1904,7 +1911,7 @@ static int32_t buildNormalTableBatchReq(
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
static
int32_t
serializeVgroupTablesBatch
(
int32_t
acctId
,
SVgroupTablesBatch
*
pTbBatch
,
SArray
*
pBufArray
)
{
static
int32_t
serializeVgroupTablesBatch
(
SVgroupTablesBatch
*
pTbBatch
,
SArray
*
pBufArray
)
{
int
tlen
=
sizeof
(
SMsgHead
)
+
tSerializeSVCreateTbBatchReq
(
NULL
,
&
(
pTbBatch
->
req
));
int
tlen
=
sizeof
(
SMsgHead
)
+
tSerializeSVCreateTbBatchReq
(
NULL
,
&
(
pTbBatch
->
req
));
void
*
buf
=
malloc
(
tlen
);
void
*
buf
=
malloc
(
tlen
);
if
(
NULL
==
buf
)
{
if
(
NULL
==
buf
)
{
...
@@ -1932,6 +1939,7 @@ static void destroyCreateTbReqBatch(SVgroupTablesBatch* pTbBatch) {
...
@@ -1932,6 +1939,7 @@ static void destroyCreateTbReqBatch(SVgroupTablesBatch* pTbBatch) {
size_t
size
=
taosArrayGetSize
(
pTbBatch
->
req
.
pArray
);
size_t
size
=
taosArrayGetSize
(
pTbBatch
->
req
.
pArray
);
for
(
int32_t
i
=
0
;
i
<
size
;
++
i
)
{
for
(
int32_t
i
=
0
;
i
<
size
;
++
i
)
{
SVCreateTbReq
*
pTableReq
=
taosArrayGet
(
pTbBatch
->
req
.
pArray
,
i
);
SVCreateTbReq
*
pTableReq
=
taosArrayGet
(
pTbBatch
->
req
.
pArray
,
i
);
tfree
(
pTableReq
->
dbFName
);
tfree
(
pTableReq
->
name
);
tfree
(
pTableReq
->
name
);
if
(
pTableReq
->
type
==
TSDB_NORMAL_TABLE
)
{
if
(
pTableReq
->
type
==
TSDB_NORMAL_TABLE
)
{
...
@@ -1973,9 +1981,9 @@ static int32_t buildCreateTableDataBlock(int32_t acctId, const SCreateTableStmt*
...
@@ -1973,9 +1981,9 @@ static int32_t buildCreateTableDataBlock(int32_t acctId, const SCreateTableStmt*
}
}
SVgroupTablesBatch
tbatch
=
{
0
};
SVgroupTablesBatch
tbatch
=
{
0
};
int32_t
code
=
buildNormalTableBatchReq
(
pStmt
->
dbName
,
pStmt
->
tableName
,
pStmt
->
pCols
,
pInfo
,
&
tbatch
);
int32_t
code
=
buildNormalTableBatchReq
(
acctId
,
pStmt
->
dbName
,
pStmt
->
tableName
,
pStmt
->
pCols
,
pInfo
,
&
tbatch
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
serializeVgroupTablesBatch
(
acctId
,
&
tbatch
,
*
pBufArray
);
code
=
serializeVgroupTablesBatch
(
&
tbatch
,
*
pBufArray
);
}
}
destroyCreateTbReqBatch
(
&
tbatch
);
destroyCreateTbReqBatch
(
&
tbatch
);
...
@@ -2004,9 +2012,16 @@ static int32_t rewriteCreateTable(STranslateContext* pCxt, SQuery* pQuery) {
...
@@ -2004,9 +2012,16 @@ static int32_t rewriteCreateTable(STranslateContext* pCxt, SQuery* pQuery) {
return
code
;
return
code
;
}
}
static
void
addCreateTbReqIntoVgroup
(
SHashObj
*
pVgroupHashmap
,
const
char
*
pDbName
,
const
char
*
pTableName
,
SKVRow
row
,
uint64_t
suid
,
SVgroupInfo
*
pVgInfo
)
{
static
void
addCreateTbReqIntoVgroup
(
int32_t
acctId
,
SHashObj
*
pVgroupHashmap
,
const
char
*
pDbName
,
const
char
*
pTableName
,
SKVRow
row
,
uint64_t
suid
,
SVgroupInfo
*
pVgInfo
)
{
char
dbFName
[
TSDB_DB_FNAME_LEN
]
=
{
0
};
SName
name
=
{
.
type
=
TSDB_DB_NAME_T
,
.
acctId
=
acctId
};
strcpy
(
name
.
dbname
,
pDbName
);
tNameGetFullDbName
(
&
name
,
dbFName
);
struct
SVCreateTbReq
req
=
{
0
};
struct
SVCreateTbReq
req
=
{
0
};
req
.
type
=
TD_CHILD_TABLE
;
req
.
type
=
TD_CHILD_TABLE
;
req
.
dbFName
=
strdup
(
dbFName
);
req
.
name
=
strdup
(
pTableName
);
req
.
name
=
strdup
(
pTableName
);
req
.
ctbCfg
.
suid
=
suid
;
req
.
ctbCfg
.
suid
=
suid
;
req
.
ctbCfg
.
pTag
=
row
;
req
.
ctbCfg
.
pTag
=
row
;
...
@@ -2159,7 +2174,7 @@ static int32_t rewriteCreateSubTable(STranslateContext* pCxt, SCreateSubTableCla
...
@@ -2159,7 +2174,7 @@ static int32_t rewriteCreateSubTable(STranslateContext* pCxt, SCreateSubTableCla
code
=
getTableHashVgroup
(
pCxt
,
pStmt
->
dbName
,
pStmt
->
tableName
,
&
info
);
code
=
getTableHashVgroup
(
pCxt
,
pStmt
->
dbName
,
pStmt
->
tableName
,
&
info
);
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
addCreateTbReqIntoVgroup
(
pVgroupHashmap
,
pStmt
->
dbName
,
pStmt
->
tableName
,
row
,
pSuperTableMeta
->
uid
,
&
info
);
addCreateTbReqIntoVgroup
(
p
Cxt
->
pParseCxt
->
acctId
,
p
VgroupHashmap
,
pStmt
->
dbName
,
pStmt
->
tableName
,
row
,
pSuperTableMeta
->
uid
,
&
info
);
}
}
tfree
(
pSuperTableMeta
);
tfree
(
pSuperTableMeta
);
...
@@ -2181,7 +2196,7 @@ static SArray* serializeVgroupsTablesBatch(int32_t acctId, SHashObj* pVgroupHash
...
@@ -2181,7 +2196,7 @@ static SArray* serializeVgroupsTablesBatch(int32_t acctId, SHashObj* pVgroupHash
break
;
break
;
}
}
serializeVgroupTablesBatch
(
acctId
,
pTbBatch
,
pBufArray
);
serializeVgroupTablesBatch
(
pTbBatch
,
pBufArray
);
destroyCreateTbReqBatch
(
pTbBatch
);
destroyCreateTbReqBatch
(
pTbBatch
);
}
while
(
true
);
}
while
(
true
);
...
...
source/libs/parser/src/parUtil.c
浏览文件 @
c3e098d7
...
@@ -71,6 +71,7 @@ int32_t generateSyntaxErrMsg(SMsgBuf* pBuf, int32_t errCode, ...) {
...
@@ -71,6 +71,7 @@ int32_t generateSyntaxErrMsg(SMsgBuf* pBuf, int32_t errCode, ...) {
va_start
(
vArgList
,
errCode
);
va_start
(
vArgList
,
errCode
);
vsnprintf
(
pBuf
->
buf
,
pBuf
->
len
,
getSyntaxErrFormat
(
errCode
),
vArgList
);
vsnprintf
(
pBuf
->
buf
,
pBuf
->
len
,
getSyntaxErrFormat
(
errCode
),
vArgList
);
va_end
(
vArgList
);
va_end
(
vArgList
);
terrno
=
errCode
;
return
errCode
;
return
errCode
;
}
}
...
...
source/libs/parser/src/sql.c
浏览文件 @
c3e098d7
...
@@ -208,135 +208,135 @@ typedef union {
...
@@ -208,135 +208,135 @@ typedef union {
** yy_default[] Default action for each state.
** yy_default[] Default action for each state.
**
**
*********** Begin parsing tables **********************************************/
*********** Begin parsing tables **********************************************/
#define YY_ACTTAB_COUNT (126
9
)
#define YY_ACTTAB_COUNT (126
6
)
static
const
YYACTIONTYPE
yy_action
[]
=
{
static
const
YYACTIONTYPE
yy_action
[]
=
{
/* 0 */
1042
,
1201
,
22
1
,
43
,
24
,
167
,
359
,
1197
,
1203
,
1092
,
/* 0 */
1042
,
1201
,
22
2
,
43
,
24
,
168
,
359
,
1197
,
1203
,
1092
,
/* 10 */
24
6
,
265
,
89
,
31
,
29
,
27
,
26
,
25
,
20
,
1201
,
/* 10 */
24
7
,
266
,
89
,
31
,
29
,
27
,
26
,
25
,
20
,
1201
,
/* 20 */
1098
,
27
,
26
,
25
,
1081
,
1197
,
1202
,
1103
,
31
,
29
,
/* 20 */
1098
,
27
,
26
,
25
,
1081
,
1197
,
1202
,
1103
,
31
,
29
,
/* 30 */
27
,
26
,
25
,
358
,
997
,
78
,
20
5
,
866
,
77
,
76
,
/* 30 */
27
,
26
,
25
,
358
,
997
,
78
,
20
6
,
866
,
77
,
76
,
/* 40 */
75
,
74
,
73
,
72
,
71
,
70
,
69
,
1088
,
20
7
,
411
,
/* 40 */
75
,
74
,
73
,
72
,
71
,
70
,
69
,
1088
,
20
8
,
411
,
/* 50 */
410
,
409
,
408
,
407
,
406
,
405
,
404
,
403
,
402
,
401
,
/* 50 */
410
,
409
,
408
,
407
,
406
,
405
,
404
,
403
,
402
,
401
,
/* 60 */
400
,
399
,
398
,
397
,
396
,
395
,
394
,
393
,
1000
,
105
,
/* 60 */
400
,
399
,
398
,
397
,
396
,
395
,
394
,
393
,
1000
,
105
,
/* 70 */
26
6
,
1011
,
878
,
31
,
29
,
27
,
26
,
25
,
1228
,
131
,
/* 70 */
26
7
,
1011
,
878
,
31
,
29
,
27
,
26
,
25
,
1228
,
131
,
/* 80 */
901
,
346
,
111
,
24
5
,
233
,
343
,
1213
,
1177
,
271
,
78
,
/* 80 */
901
,
346
,
111
,
24
6
,
234
,
343
,
1213
,
1177
,
272
,
78
,
/* 90 */
130
,
22
,
77
,
76
,
75
,
74
,
73
,
72
,
71
,
70
,
/* 90 */
130
,
22
,
77
,
76
,
75
,
74
,
73
,
72
,
71
,
70
,
/* 100 */
69
,
31
,
29
,
27
,
26
,
25
,
1228
,
1314
,
20
7
,
287
,
/* 100 */
69
,
31
,
29
,
27
,
26
,
25
,
1228
,
1314
,
20
8
,
288
,
/* 110 */
31
6
,
282
,
266
,
343
,
286
,
44
,
902
,
285
,
128
,
283
,
/* 110 */
31
7
,
283
,
267
,
343
,
287
,
44
,
902
,
286
,
128
,
284
,
/* 120 */
117
,
342
,
28
4
,
345
,
1312
,
23
,
228
,
1189
,
896
,
897
,
/* 120 */
117
,
342
,
28
5
,
345
,
1312
,
23
,
229
,
1189
,
896
,
897
,
/* 130 */
898
,
899
,
900
,
904
,
905
,
906
,
1079
,
20
0
,
1214
,
1217
,
/* 130 */
898
,
899
,
900
,
904
,
905
,
906
,
1079
,
20
1
,
1214
,
1217
,
/* 140 */
901
,
769
,
382
,
381
,
380
,
773
,
379
,
775
,
776
,
378
,
/* 140 */
901
,
769
,
382
,
381
,
380
,
773
,
379
,
775
,
776
,
378
,
/* 150 */
778
,
375
,
109
,
784
,
372
,
786
,
787
,
369
,
366
,
1148
,
/* 150 */
778
,
375
,
109
,
784
,
372
,
786
,
787
,
369
,
366
,
1148
,
/* 160 */
1213
,
846
,
127
,
1141
,
30
1
,
220
,
125
,
43
,
323
,
185
,
/* 160 */
1213
,
846
,
127
,
1141
,
30
2
,
221
,
125
,
43
,
323
,
186
,
/* 170 */
1146
,
358
,
1133
,
30
,
28
,
938
,
902
,
844
,
25
4
,
238
,
/* 170 */
1146
,
358
,
1133
,
30
,
28
,
938
,
902
,
844
,
25
5
,
239
,
/* 180 */
1228
,
23
0
,
392
,
846
,
1099
,
23
,
228
,
343
,
896
,
897
,
/* 180 */
1228
,
23
1
,
392
,
846
,
1099
,
23
,
229
,
343
,
896
,
897
,
/* 190 */
898
,
899
,
900
,
904
,
905
,
906
,
1201
,
345
,
358
,
844
,
/* 190 */
898
,
899
,
900
,
904
,
905
,
906
,
1201
,
345
,
358
,
844
,
/* 200 */
893
,
1189
,
1197
,
1202
,
30
2
,
359
,
331
,
845
,
12
,
118
,
/* 200 */
893
,
1189
,
1197
,
1202
,
30
3
,
359
,
331
,
845
,
12
,
118
,
/* 210 */
66
,
61
,
1214
,
1217
,
1253
,
1213
,
962
,
27
5
,
206
,
1249
,
/* 210 */
66
,
61
,
1214
,
1217
,
1253
,
1213
,
962
,
27
6
,
207
,
1249
,
/* 220 */
1165
,
10
,
122
,
121
,
30
,
28
,
1103
,
120
,
1314
,
845
,
/* 220 */
1165
,
10
,
122
,
121
,
30
,
28
,
1103
,
120
,
1314
,
845
,
/* 230 */
1314
,
1
,
23
0
,
423
,
846
,
1228
,
312
,
960
,
961
,
963
,
/* 230 */
1314
,
1
,
23
1
,
423
,
846
,
1228
,
313
,
960
,
961
,
963
,
/* 240 */
964
,
117
,
330
,
117
,
1213
,
1312
,
24
1
,
1312
,
10
,
321
,
/* 240 */
964
,
117
,
330
,
117
,
1213
,
1312
,
24
2
,
1312
,
10
,
321
,
/* 250 */
844
,
334
,
345
,
1168
,
1170
,
423
,
1189
,
346
,
696
,
12
,
/* 250 */
844
,
334
,
345
,
1168
,
1170
,
423
,
1189
,
346
,
696
,
12
,
/* 260 */
695
,
847
,
850
,
1178
,
1228
,
359
,
62
,
1214
,
1217
,
1253
,
/* 260 */
695
,
847
,
850
,
1178
,
1228
,
359
,
62
,
1214
,
1217
,
1253
,
/* 270 */
66
,
330
,
2
79
,
223
,
1249
,
112
,
278
,
281
,
697
,
327
,
/* 270 */
66
,
330
,
2
80
,
224
,
1249
,
112
,
279
,
282
,
697
,
327
,
/* 280 */
845
,
345
,
1
,
847
,
850
,
1189
,
1103
,
16
3
,
118
,
9
,
/* 280 */
845
,
345
,
1
,
847
,
850
,
1189
,
1103
,
16
4
,
118
,
9
,
/* 290 */
8
,
59
,
1213
,
30
8
,
1280
,
62
,
1214
,
1217
,
1253
,
280
,
/* 290 */
8
,
59
,
1213
,
30
9
,
1280
,
62
,
1214
,
1217
,
1253
,
281
,
/* 300 */
92
,
93
,
22
3
,
1249
,
112
,
1314
,
423
,
327
,
1095
,
106
,
/* 300 */
92
,
93
,
22
4
,
1249
,
112
,
1314
,
423
,
327
,
1095
,
106
,
/* 310 */
1070
,
903
,
1228
,
31
,
29
,
27
,
26
,
25
,
1313
,
343
,
/* 310 */
1070
,
903
,
1228
,
31
,
29
,
27
,
26
,
25
,
1313
,
343
,
/* 320 */
21
,
1213
,
1312
,
1281
,
392
,
1267
,
90
,
868
,
92
,
345
,
/* 320 */
21
,
1213
,
1312
,
1281
,
392
,
1267
,
90
,
868
,
92
,
345
,
/* 330 */
907
,
419
,
418
,
1189
,
847
,
850
,
114
,
1260
,
1261
,
867
,
/* 330 */
907
,
419
,
418
,
1189
,
847
,
850
,
114
,
1260
,
1261
,
867
,
/* 340 */
1265
,
1228
,
1264
,
62
,
1214
,
1217
,
1253
,
331
,
343
,
118
,
/* 340 */
1265
,
1228
,
1264
,
62
,
1214
,
1217
,
1253
,
331
,
343
,
118
,
/* 350 */
22
3
,
1249
,
1326
,
695
,
90
,
1094
,
1213
,
864
,
345
,
914
,
/* 350 */
22
4
,
1249
,
1326
,
695
,
90
,
1094
,
1213
,
864
,
345
,
914
,
/* 360 */
1228
,
1287
,
1189
,
865
,
16
0
,
1260
,
326
,
343
,
325
,
273
,
/* 360 */
1228
,
1287
,
1189
,
865
,
16
1
,
1260
,
326
,
343
,
325
,
274
,
/* 370 */
23
4
,
1314
,
62
,
1214
,
1217
,
1253
,
1228
,
359
,
104
,
223
,
/* 370 */
23
5
,
1314
,
62
,
1214
,
1217
,
1253
,
1228
,
359
,
104
,
224
,
/* 380 */
1249
,
1326
,
1100
,
343
,
117
,
1213
,
1105
,
385
,
1312
,
1022
,
/* 380 */
1249
,
1326
,
1100
,
343
,
117
,
1213
,
1105
,
385
,
1312
,
1022
,
/* 390 */
1310
,
1090
,
320
,
345
,
30
,
28
,
1189
,
1189
,
1103
,
1021
,
/* 390 */
1310
,
1090
,
320
,
345
,
30
,
28
,
1189
,
1189
,
1103
,
1021
,
/* 400 */
1267
,
333
,
23
0
,
104
,
846
,
1228
,
1080
,
62
,
1214
,
1217
,
/* 400 */
1267
,
333
,
23
1
,
104
,
846
,
1228
,
1080
,
62
,
1214
,
1217
,
/* 410 */
1253
,
1106
,
343
,
1148
,
22
3
,
1249
,
1326
,
1263
,
359
,
235
,
/* 410 */
1253
,
1106
,
343
,
1148
,
22
4
,
1249
,
1326
,
1263
,
359
,
236
,
/* 420 */
844
,
1148
,
345
,
356
,
1146
,
1271
,
1189
,
24
2
,
162
,
12
,
/* 420 */
844
,
1148
,
345
,
356
,
1146
,
1271
,
1189
,
24
3
,
163
,
12
,
/* 430 */
1189
,
331
,
1146
,
30
,
28
,
1012
,
19
5
,
1214
,
1217
,
1103
,
/* 430 */
1189
,
331
,
1146
,
30
,
28
,
1012
,
19
6
,
1214
,
1217
,
1103
,
/* 440 */
1189
,
23
0
,
1213
,
846
,
190
,
1020
,
1019
,
1018
,
136
,
192
,
/* 440 */
1189
,
23
1
,
1213
,
846
,
191
,
1020
,
1019
,
1018
,
136
,
193
,
/* 450 */
845
,
134
,
1
,
1038
,
31
5
,
1314
,
30
,
28
,
344
,
844
,
/* 450 */
845
,
134
,
1
,
1038
,
31
6
,
1314
,
30
,
28
,
344
,
844
,
/* 460 */
6
,
19
1
,
1228
,
389
,
230
,
1213
,
846
,
388
,
117
,
343
,
/* 460 */
6
,
19
2
,
1228
,
389
,
231
,
1213
,
846
,
388
,
117
,
343
,
/* 470 */
1017
,
123
,
1312
,
1148
,
118
,
28
8
,
423
,
322
,
317
,
345
,
/* 470 */
1017
,
123
,
1312
,
1148
,
118
,
28
9
,
423
,
322
,
318
,
345
,
/* 480 */
1016
,
1015
,
844
,
1189
,
1169
,
1228
,
1189
,
1189
,
1189
,
845
,
/* 480 */
1016
,
1015
,
844
,
1189
,
1169
,
1228
,
1189
,
1189
,
1189
,
845
,
/* 490 */
390
,
7
,
343
,
63
,
1214
,
1217
,
1253
,
1148
,
869
,
1086
,
/* 490 */
390
,
7
,
343
,
63
,
1214
,
1217
,
1253
,
1148
,
869
,
1086
,
/* 500 */
1252
,
1249
,
345
,
1045
,
847
,
850
,
1189
,
945
,
1147
,
387
,
/* 500 */
1252
,
1249
,
345
,
1045
,
847
,
850
,
1189
,
945
,
1147
,
387
,
/* 510 */
386
,
1189
,
845
,
866
,
7
,
423
,
63
,
1214
,
1217
,
1253
,
/* 510 */
386
,
1189
,
845
,
866
,
7
,
423
,
63
,
1214
,
1217
,
1253
,
/* 520 */
24
0
,
1189
,
1189
,
341
,
1249
,
30
,
28
,
299
,
104
,
30
,
/* 520 */
24
1
,
1189
,
1189
,
341
,
1249
,
30
,
28
,
300
,
104
,
30
,
/* 530 */
28
,
64
,
384
,
23
0
,
338
,
846
,
1105
,
230
,
423
,
846
,
/* 530 */
28
,
64
,
384
,
23
1
,
338
,
846
,
1105
,
231
,
423
,
846
,
/* 540 */
29
7
,
1213
,
1267
,
847
,
850
,
999
,
31
,
29
,
27
,
26
,
/* 540 */
29
8
,
1213
,
1267
,
847
,
850
,
999
,
31
,
29
,
27
,
26
,
/* 550 */
25
,
844
,
28
7
,
933
,
282
,
844
,
1014
,
286
,
118
,
1262
,
/* 550 */
25
,
844
,
28
8
,
933
,
283
,
844
,
1014
,
287
,
118
,
1262
,
/* 560 */
28
5
,
1228
,
283
,
118
,
1213
,
284
,
847
,
850
,
343
,
87
,
/* 560 */
28
6
,
1228
,
284
,
118
,
1213
,
285
,
847
,
850
,
343
,
87
,
/* 570 */
86
,
85
,
84
,
83
,
82
,
81
,
80
,
79
,
345
,
864
,
/* 570 */
86
,
85
,
84
,
83
,
82
,
81
,
80
,
79
,
345
,
864
,
/* 580 */
1033
,
845
,
1189
,
7
,
1228
,
845
,
24
7
,
1
,
1071
,
259
,
/* 580 */
1033
,
845
,
1189
,
7
,
1228
,
845
,
24
8
,
1
,
1071
,
260
,
/* 590 */
1013
,
343
,
107
,
1214
,
1217
,
937
,
426
,
1189
,
26
0
,
149
,
/* 590 */
1013
,
343
,
107
,
1214
,
1217
,
937
,
426
,
1189
,
26
1
,
149
,
/* 600 */
1213
,
345
,
29
0
,
164
,
359
,
1189
,
243
,
423
,
339
,
357
,
/* 600 */
1213
,
345
,
29
1
,
165
,
359
,
1189
,
244
,
423
,
339
,
357
,
/* 610 */
18
3
,
423
,
304
,
88
,
104
,
63
,
1214
,
1217
,
1253
,
415
,
/* 610 */
18
4
,
423
,
305
,
88
,
104
,
63
,
1214
,
1217
,
1253
,
415
,
/* 620 */
1228
,
18
2
,
1105
,
1250
,
98
,
1103
,
1010
,
343
,
313
,
332
,
/* 620 */
1228
,
18
3
,
1105
,
1250
,
98
,
1103
,
1010
,
343
,
314
,
332
,
/* 630 */
1327
,
1189
,
1031
,
1009
,
1008
,
847
,
850
,
345
,
359
,
847
,
/* 630 */
1327
,
1189
,
1031
,
1009
,
1008
,
847
,
850
,
345
,
359
,
847
,
/* 640 */
850
,
1189
,
1142
,
18
0
,
229
,
359
,
60
,
1007
,
1006
,
178
,
/* 640 */
850
,
1189
,
1142
,
18
1
,
230
,
359
,
60
,
1007
,
1006
,
179
,
/* 650 */
24
4
,
201
,
1214
,
1217
,
293
,
1005
,
157
,
1004
,
1213
,
1103
,
/* 650 */
24
5
,
202
,
1214
,
1217
,
294
,
1005
,
158
,
1004
,
1213
,
1103
,
/* 660 */
1272
,
933
,
1229
,
1213
,
27
2
,
258
,
1103
,
1189
,
253
,
252
,
/* 660 */
1272
,
933
,
1229
,
1213
,
27
3
,
259
,
1103
,
1189
,
254
,
253
,
/* 670 */
25
1
,
250
,
249
,
335
,
1189
,
1189
,
1003
,
853
,
1228
,
138
,
/* 670 */
25
2
,
251
,
250
,
335
,
1189
,
1189
,
1003
,
853
,
1228
,
138
,
/* 680 */
355
,
1213
,
137
,
1228
,
140
,
343
,
1213
,
139
,
1189
,
1189
,
/* 680 */
355
,
1213
,
137
,
1228
,
140
,
343
,
1213
,
139
,
1189
,
1189
,
/* 690 */
343
,
852
,
991
,
992
,
30
7
,
345
,
1189
,
146
,
1189
,
1189
,
/* 690 */
343
,
852
,
991
,
992
,
30
8
,
345
,
1189
,
146
,
1189
,
1189
,
/* 700 */
345
,
1228
,
3
09
,
327
,
1189
,
328
,
1228
,
856
,
343
,
201
,
/* 700 */
345
,
1228
,
3
10
,
327
,
1189
,
328
,
1228
,
856
,
343
,
202
,
/* 710 */
1214
,
1217
,
1002
,
343
,
107
,
1214
,
1217
,
1189
,
345
,
9
,
/* 710 */
1214
,
1217
,
1002
,
343
,
107
,
1214
,
1217
,
1189
,
345
,
9
,
/* 720 */
8
,
855
,
1189
,
345
,
92
,
22
7
,
864
,
1189
,
1213
,
936
,
/* 720 */
8
,
855
,
1189
,
345
,
92
,
22
8
,
864
,
1189
,
1213
,
936
,
/* 730 */
23
1
,
1213
,
201
,
1214
,
1217
,
1283
,
1213
,
201
,
1214
,
1217
,
/* 730 */
23
2
,
1213
,
202
,
1214
,
1217
,
1283
,
1213
,
202
,
1214
,
1217
,
/* 740 */
31
,
29
,
27
,
26
,
25
,
336
,
327
,
1167
,
1228
,
52
,
/* 740 */
31
,
29
,
27
,
26
,
25
,
336
,
327
,
1167
,
1228
,
52
,
/* 750 */
90
,
1228
,
1328
,
1189
,
16
6
,
343
,
1228
,
1078
,
343
,
329
,
/* 750 */
90
,
1228
,
1328
,
1189
,
16
7
,
343
,
1228
,
1078
,
343
,
329
,
/* 760 */
113
,
1260
,
1261
,
343
,
1265
,
345
,
1096
,
92
,
345
,
1189
,
/* 760 */
113
,
1260
,
1261
,
343
,
1265
,
345
,
1096
,
92
,
345
,
1189
,
/* 770 */
2
,
119
,
1189
,
345
,
1213
,
142
,
25
6
,
1189
,
141
,
199
,
/* 770 */
2
,
119
,
1189
,
345
,
1213
,
142
,
25
7
,
1189
,
141
,
200
,
/* 780 */
1214
,
1217
,
20
2
,
1214
,
1217
,
959
,
154
,
193
,
1214
,
1217
,
/* 780 */
1214
,
1217
,
20
3
,
1214
,
1217
,
959
,
154
,
194
,
1214
,
1217
,
/* 790 */
24
8
,
255
,
257
,
90
,
1228
,
261
,
1213
,
41
,
152
,
878
,
/* 790 */
24
9
,
256
,
258
,
90
,
1228
,
262
,
1213
,
41
,
152
,
878
,
/* 800 */
908
,
343
,
1213
,
115
,
1260
,
1261
,
872
,
1265
,
994
,
995
,
/* 800 */
908
,
343
,
1213
,
115
,
1260
,
1261
,
872
,
1265
,
994
,
995
,
/* 810 */
26
2
,
345
,
32
,
263
,
389
,
1189
,
1228
,
124
,
388
,
871
,
/* 810 */
26
3
,
345
,
32
,
264
,
389
,
1189
,
1228
,
124
,
388
,
871
,
/* 820 */
875
,
58
,
1228
,
343
,
42
,
20
3
,
1214
,
1217
,
1207
,
343
,
/* 820 */
875
,
58
,
1228
,
343
,
42
,
20
4
,
1214
,
1217
,
1207
,
343
,
/* 830 */
1213
,
54
,
32
,
345
,
839
,
26
4
,
1213
,
1189
,
267
,
345
,
/* 830 */
1213
,
54
,
32
,
345
,
839
,
26
5
,
1213
,
1189
,
268
,
345
,
/* 840 */
1205
,
390
,
129
,
1189
,
27
4
,
870
,
32
,
194
,
1214
,
1217
,
/* 840 */
1205
,
390
,
129
,
1189
,
27
5
,
870
,
32
,
195
,
1214
,
1217
,
/* 850 */
1228
,
27
6
,
68
,
204
,
1214
,
1217
,
1228
,
343
,
172
,
1093
,
/* 850 */
1228
,
27
7
,
68
,
205
,
1214
,
1217
,
1228
,
343
,
173
,
1093
,
/* 860 */
387
,
386
,
2
19
,
343
,
1213
,
133
,
351
,
345
,
177
,
1089
,
/* 860 */
387
,
386
,
2
20
,
343
,
1213
,
133
,
351
,
345
,
178
,
1089
,
/* 870 */
17
0
,
1189
,
135
,
345
,
762
,
100
,
101
,
1189
,
95
,
1091
,
/* 870 */
17
1
,
1189
,
135
,
345
,
762
,
100
,
101
,
1189
,
95
,
1091
,
/* 880 */
96
,
1225
,
1214
,
1217
,
1228
,
1087
,
98
,
1224
,
1214
,
1217
,
/* 880 */
96
,
1225
,
1214
,
1217
,
1228
,
1087
,
98
,
1224
,
1214
,
1217
,
/* 890 */
757
,
343
,
1213
,
102
,
790
,
794
,
103
,
800
,
1213
,
799
,
/* 890 */
757
,
343
,
1213
,
102
,
790
,
794
,
103
,
800
,
1213
,
799
,
/* 900 */
30
6
,
345
,
41
,
303
,
145
,
1189
,
364
,
96
,
99
,
97
,
/* 900 */
30
7
,
345
,
41
,
304
,
145
,
1189
,
364
,
96
,
99
,
97
,
/* 910 */
30
5
,
98
,
1228
,
869
,
314
,
1223
,
1214
,
1217
,
1228
,
343
,
/* 910 */
30
6
,
98
,
1228
,
869
,
315
,
1223
,
1214
,
1217
,
1228
,
343
,
/* 920 */
96
,
1284
,
349
,
1294
,
150
,
343
,
31
1
,
850
,
1293
,
345
,
/* 920 */
96
,
1284
,
349
,
1294
,
150
,
343
,
31
2
,
850
,
1293
,
345
,
/* 930 */
153
,
22
2
,
1213
,
1189
,
5
,
345
,
324
,
110
,
1274
,
1189
,
/* 930 */
153
,
22
3
,
1213
,
1189
,
319
,
345
,
5
,
110
,
1274
,
1189
,
/* 940 */
1213
,
3
10
,
156
,
210
,
1214
,
1217
,
237
,
236
,
4
,
209
,
/* 940 */
1213
,
3
24
,
157
,
211
,
1214
,
1217
,
238
,
237
,
311
,
210
,
/* 950 */
1214
,
1217
,
1228
,
933
,
91
,
868
,
858
,
1268
,
33
,
343
,
/* 950 */
1214
,
1217
,
1228
,
4
,
933
,
91
,
858
,
868
,
1268
,
343
,
/* 960 */
1228
,
159
,
158
,
340
,
1311
,
224
,
1329
,
343
,
1213
,
345
,
/* 960 */
1228
,
33
,
159
,
160
,
1311
,
225
,
1329
,
343
,
1213
,
345
,
/* 970 */
337
,
165
,
851
,
1189
,
292
,
214
,
17
,
345
,
1235
,
1176
,
/* 970 */
337
,
340
,
851
,
1189
,
293
,
215
,
166
,
345
,
17
,
1235
,
/* 980 */
347
,
1189
,
348
,
211
,
1214
,
1217
,
352
,
1175
,
1228
,
300
,
/* 980 */
1176
,
1189
,
347
,
212
,
1214
,
1217
,
348
,
233
,
1228
,
301
,
/* 990 */
232
,
208
,
1214
,
1217
,
353
,
343
,
354
,
279
,
51
,
174
,
/* 990 */
1175
,
209
,
1214
,
1217
,
352
,
343
,
353
,
280
,
354
,
175
,
/* 1000 */
184
,
278
,
854
,
144
,
1104
,
345
,
295
,
53
,
186
,
1189
,
/* 1000 */
51
,
279
,
854
,
144
,
185
,
345
,
296
,
187
,
53
,
1189
,
/* 1010 */
362
,
289
,
181
,
215
,
143
,
213
,
212
,
422
,
277
,
198
,
/* 1010 */
1104
,
290
,
182
,
216
,
143
,
214
,
213
,
422
,
278
,
199
,
/* 1020 */
1214
,
1217
,
196
,
197
,
280
,
188
,
189
,
1183
,
360
,
822
,
/* 1020 */
1214
,
1217
,
362
,
197
,
281
,
198
,
189
,
190
,
360
,
1183
,
/* 1030 */
1160
,
1159
,
94
,
1158
,
1157
,
1156
,
1155
,
1154
,
1153
,
40
,
/* 1030 */
822
,
1160
,
1159
,
94
,
1158
,
1157
,
1156
,
1155
,
1154
,
40
,
/* 1040 */
824
,
1152
,
39
,
1151
,
1150
,
1149
,
1044
,
1182
,
1173
,
126
,
/* 1040 */
1153
,
824
,
39
,
1152
,
1151
,
1150
,
1149
,
1044
,
1182
,
1173
,
/* 1050 */
1082
,
708
,
1043
,
1041
,
268
,
269
,
859
,
850
,
270
,
1030
,
/* 1050 */
126
,
1082
,
708
,
1043
,
1041
,
269
,
859
,
850
,
270
,
271
,
/* 1060 */
10
29
,
1026
,
1084
,
67
,
132
,
1083
,
805
,
804
,
1039
,
1034
,
/* 1060 */
10
30
,
1029
,
1026
,
1084
,
67
,
132
,
805
,
1083
,
804
,
1039
,
/* 1070 */
737
,
803
,
1032
,
1025
,
1024
,
1181
,
65
,
736
,
735
,
216
,
/* 1070 */
1034
,
737
,
803
,
1032
,
1025
,
1024
,
1181
,
736
,
217
,
735
,
/* 1080 */
734
,
1180
,
36
,
1172
,
45
,
217
,
218
,
148
,
296
,
73
3
,
/* 1080 */
734
,
218
,
1180
,
36
,
1172
,
45
,
219
,
148
,
297
,
3
,
/* 1090 */
3
,
32
,
732
,
298
,
291
,
14
,
294
,
151
,
15
,
34
,
/* 1090 */
733
,
65
,
32
,
732
,
299
,
14
,
292
,
151
,
958
,
15
,
/* 1100 */
37
,
11
,
48
,
319
,
1205
,
8
,
19
,
161
,
894
,
350
,
/* 1100 */
1205
,
147
,
162
,
295
,
37
,
11
,
156
,
19
,
34
,
48
,
/* 1110 */
147
,
176
,
998
,
998
,
998
,
998
,
998
,
318
,
1171
,
998
,
/* 1110 */
8
,
350
,
894
,
1171
,
177
,
998
,
998
,
998
,
998
,
998
,
/* 1120 */
783
,
998
,
998
,
998
,
998
,
998
,
998
,
998
,
998
,
980
,
/* 1120 */
998
,
783
,
998
,
998
,
998
,
998
,
998
,
998
,
980
,
979
,
/* 1130 */
979
,
225
,
984
,
983
,
226
,
998
,
998
,
998
,
99
8
,
998
,
/* 1130 */
226
,
984
,
983
,
227
,
860
,
998
,
998
,
998
,
10
8
,
998
,
/* 1140 */
998
,
958
,
998
,
175
,
998
,
998
,
10
8
,
155
,
998
,
952
,
/* 1140 */
998
,
176
,
998
,
998
,
998
,
998
,
99
8
,
155
,
998
,
952
,
/* 1150 */
46
,
998
,
860
,
951
,
47
,
768
,
930
,
929
,
998
,
985
,
/* 1150 */
46
,
998
,
951
,
47
,
998
,
768
,
930
,
929
,
998
,
985
,
/* 1160 */
998
,
998
,
998
,
998
,
998
,
998
,
998
,
998
,
998
,
13
,
/* 1160 */
998
,
998
,
35
,
998
,
998
,
998
,
998
,
998
,
876
,
116
,
/* 1170 */
35
,
116
,
876
,
16
,
18
,
998
,
169
,
956
,
171
,
168
,
/* 1170 */
13
,
18
,
16
,
170
,
956
,
998
,
172
,
174
,
169
,
49
,
/* 1180 */
49
,
173
,
50
,
998
,
1204
,
363
,
239
,
54
,
367
,
38
,
/* 1180 */
50
,
1204
,
998
,
998
,
54
,
38
,
363
,
1040
,
240
,
367
,
/* 1190 */
10
40
,
179
,
370
,
373
,
998
,
998
,
998
,
998
,
376
,
998
,
/* 1190 */
10
28
,
370
,
373
,
180
,
998
,
361
,
998
,
796
,
376
,
998
,
/* 1200 */
998
,
796
,
998
,
791
,
365
,
998
,
788
,
728
,
720
,
998
,
/* 1200 */
791
,
365
,
728
,
788
,
368
,
1027
,
785
,
998
,
798
,
371
,
/* 1210 */
420
,
848
,
361
,
785
,
368
,
798
,
797
,
782
,
998
,
998
,
/* 1210 */
420
,
720
,
797
,
779
,
998
,
998
,
998
,
727
,
782
,
998
,
/* 1220 */
72
7
,
371
,
998
,
998
,
779
,
726
,
55
,
374
,
706
,
777
,
/* 1220 */
72
6
,
998
,
998
,
725
,
724
,
706
,
781
,
374
,
391
,
777
,
/* 1230 */
391
,
725
,
724
,
1028
,
414
,
1027
,
1023
,
723
,
413
,
998
,
/* 1230 */
723
,
722
,
721
,
377
,
719
,
1023
,
718
,
717
,
413
,
716
,
/* 1240 */
3
77
,
998
,
722
,
721
,
56
,
57
,
719
,
718
,
187
,
729
,
/* 1240 */
3
83
,
55
,
56
,
57
,
425
,
715
,
729
,
714
,
713
,
421
,
/* 1250 */
421
,
717
,
716
,
715
,
714
,
713
,
712
,
383
,
424
,
711
,
/* 1250 */
712
,
711
,
412
,
848
,
188
,
424
,
998
,
416
,
417
,
998
,
/* 1260 */
412
,
425
,
998
,
416
,
417
,
998
,
998
,
781
,
780
,
/* 1260 */
998
,
414
,
998
,
998
,
998
,
780
,
};
};
static
const
YYCODETYPE
yy_lookahead
[]
=
{
static
const
YYCODETYPE
yy_lookahead
[]
=
{
/* 0 */
0
,
207
,
190
,
174
,
221
,
222
,
172
,
213
,
214
,
187
,
/* 0 */
0
,
207
,
190
,
174
,
221
,
222
,
172
,
213
,
214
,
187
,
...
@@ -432,40 +432,40 @@ static const YYCODETYPE yy_lookahead[] = {
...
@@ -432,40 +432,40 @@ static const YYCODETYPE yy_lookahead[] = {
/* 900 */
204
,
203
,
83
,
211
,
171
,
207
,
83
,
83
,
71
,
83
,
/* 900 */
204
,
203
,
83
,
211
,
171
,
207
,
83
,
83
,
71
,
83
,
/* 910 */
193
,
83
,
186
,
20
,
145
,
217
,
218
,
219
,
186
,
193
,
/* 910 */
193
,
83
,
186
,
20
,
145
,
217
,
218
,
219
,
186
,
193
,
/* 920 */
83
,
216
,
144
,
246
,
208
,
193
,
207
,
123
,
246
,
203
,
/* 920 */
83
,
216
,
144
,
246
,
208
,
193
,
207
,
123
,
246
,
203
,
/* 930 */
208
,
207
,
166
,
207
,
152
,
203
,
151
,
240
,
243
,
207
,
/* 930 */
208
,
207
,
166
,
207
,
207
,
203
,
152
,
240
,
243
,
207
,
/* 940 */
166
,
1
40
,
242
,
217
,
218
,
219
,
12
,
13
,
139
,
217
,
/* 940 */
166
,
1
51
,
242
,
217
,
218
,
219
,
12
,
13
,
140
,
217
,
/* 950 */
218
,
219
,
186
,
13
6
,
193
,
20
,
22
,
215
,
114
,
193
,
/* 950 */
218
,
219
,
186
,
13
9
,
136
,
193
,
22
,
20
,
215
,
193
,
/* 960 */
186
,
227
,
239
,
156
,
252
,
160
,
257
,
193
,
166
,
203
,
/* 960 */
186
,
114
,
239
,
227
,
252
,
160
,
257
,
193
,
166
,
203
,
/* 970 */
154
,
251
,
38
,
207
,
4
,
35
,
70
,
203
,
223
,
208
,
/* 970 */
154
,
156
,
38
,
207
,
4
,
35
,
251
,
203
,
70
,
223
,
/* 980 */
20
7
,
207
,
207
,
217
,
218
,
219
,
118
,
208
,
186
,
19
,
/* 980 */
20
8
,
207
,
207
,
217
,
218
,
219
,
207
,
207
,
186
,
19
,
/* 990 */
20
7
,
217
,
218
,
219
,
205
,
193
,
204
,
57
,
171
,
193
,
/* 990 */
20
8
,
217
,
218
,
219
,
118
,
193
,
205
,
57
,
204
,
193
,
/* 1000 */
1
82
,
61
,
68
,
33
,
193
,
203
,
36
,
70
,
172
,
207
,
/* 1000 */
1
71
,
61
,
68
,
33
,
182
,
203
,
36
,
172
,
70
,
207
,
/* 1010 */
1
89
,
41
,
171
,
73
,
44
,
75
,
76
,
168
,
78
,
217
,
/* 1010 */
1
93
,
41
,
171
,
73
,
44
,
75
,
76
,
168
,
78
,
217
,
/* 1020 */
218
,
219
,
18
0
,
180
,
84
,
173
,
164
,
0
,
94
,
82
,
/* 1020 */
218
,
219
,
18
9
,
180
,
84
,
180
,
173
,
164
,
94
,
0
,
/* 1030 */
0
,
0
,
114
,
0
,
0
,
0
,
0
,
0
,
0
,
69
,
/* 1030 */
82
,
0
,
0
,
114
,
0
,
0
,
0
,
0
,
0
,
69
,
/* 1040 */
22
,
0
,
72
,
0
,
0
,
0
,
0
,
0
,
0
,
43
,
/* 1040 */
0
,
22
,
72
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
/* 1050 */
0
,
48
,
0
,
0
,
38
,
36
,
122
,
123
,
43
,
0
,
/* 1050 */
43
,
0
,
48
,
0
,
0
,
38
,
122
,
123
,
36
,
43
,
/* 1060 */
0
,
0
,
0
,
79
,
77
,
0
,
38
,
38
,
0
,
0
,
/* 1060 */
0
,
0
,
0
,
0
,
79
,
77
,
38
,
0
,
38
,
0
,
/* 1070 */
38
,
22
,
0
,
0
,
0
,
0
,
20
,
38
,
38
,
22
,
/* 1070 */
0
,
38
,
22
,
0
,
0
,
0
,
0
,
38
,
22
,
38
,
/* 1080 */
38
,
0
,
121
,
0
,
70
,
22
,
22
,
116
,
22
,
38
,
/* 1080 */
38
,
22
,
0
,
121
,
0
,
70
,
22
,
116
,
22
,
83
,
/* 1090 */
83
,
83
,
38
,
22
,
39
,
141
,
38
,
71
,
141
,
135
,
/* 1090 */
38
,
20
,
83
,
38
,
22
,
141
,
39
,
71
,
71
,
141
,
/* 1100 */
8
3
,
141
,
4
,
83
,
82
,
2
,
83
,
82
,
126
,
119
,
/* 1100 */
8
2
,
43
,
82
,
38
,
83
,
141
,
83
,
83
,
135
,
4
,
/* 1110 */
43
,
116
,
258
,
258
,
258
,
258
,
258
,
38
,
0
,
258
,
/* 1110 */
2
,
119
,
126
,
0
,
116
,
258
,
258
,
258
,
258
,
258
,
/* 1120 */
96
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
25
8
,
38
,
/* 1120 */
258
,
96
,
258
,
258
,
258
,
258
,
258
,
258
,
3
8
,
38
,
/* 1130 */
38
,
38
,
38
,
38
,
38
,
258
,
258
,
258
,
258
,
258
,
/* 1130 */
38
,
38
,
38
,
38
,
22
,
258
,
258
,
258
,
70
,
258
,
/* 1140 */
258
,
71
,
258
,
43
,
258
,
258
,
70
,
70
,
258
,
71
,
/* 1140 */
258
,
43
,
258
,
258
,
258
,
258
,
258
,
70
,
258
,
71
,
/* 1150 */
70
,
258
,
22
,
71
,
70
,
22
,
71
,
71
,
258
,
71
,
/* 1150 */
70
,
258
,
71
,
70
,
258
,
22
,
71
,
71
,
258
,
71
,
/* 1160 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
70
,
/* 1160 */
258
,
258
,
83
,
258
,
258
,
258
,
258
,
258
,
71
,
82
,
/* 1170 */
83
,
82
,
71
,
83
,
70
,
258
,
71
,
71
,
70
,
82
,
/* 1170 */
70
,
70
,
83
,
71
,
71
,
258
,
70
,
70
,
82
,
70
,
/* 1180 */
70
,
70
,
70
,
258
,
82
,
38
,
38
,
80
,
38
,
70
,
/* 1180 */
70
,
82
,
258
,
258
,
80
,
70
,
38
,
0
,
38
,
38
,
/* 1190 */
0
,
82
,
38
,
38
,
258
,
258
,
258
,
258
,
38
,
258
,
/* 1190 */
0
,
38
,
38
,
82
,
258
,
81
,
258
,
22
,
38
,
258
,
/* 1200 */
258
,
22
,
258
,
71
,
70
,
258
,
71
,
22
,
22
,
258
,
/* 1200 */
71
,
70
,
22
,
71
,
70
,
0
,
71
,
258
,
38
,
70
,
/* 1210 */
22
,
22
,
81
,
71
,
70
,
38
,
38
,
96
,
258
,
258
,
/* 1210 */
22
,
22
,
38
,
71
,
258
,
258
,
258
,
38
,
96
,
258
,
/* 1220 */
38
,
70
,
258
,
258
,
71
,
38
,
70
,
70
,
48
,
71
,
/* 1220 */
38
,
258
,
258
,
38
,
38
,
48
,
96
,
70
,
47
,
71
,
/* 1230 */
47
,
38
,
38
,
0
,
43
,
0
,
0
,
38
,
36
,
25
8
,
/* 1230 */
38
,
38
,
38
,
70
,
38
,
0
,
38
,
38
,
36
,
3
8
,
/* 1240 */
70
,
258
,
38
,
38
,
70
,
70
,
38
,
38
,
22
,
68
,
/* 1240 */
84
,
70
,
70
,
70
,
20
,
38
,
68
,
38
,
38
,
21
,
/* 1250 */
21
,
38
,
38
,
38
,
38
,
38
,
38
,
84
,
21
,
3
8
,
/* 1250 */
38
,
38
,
38
,
22
,
22
,
21
,
258
,
38
,
37
,
25
8
,
/* 1260 */
38
,
20
,
258
,
38
,
37
,
258
,
258
,
96
,
96
,
258
,
/* 1260 */
258
,
43
,
258
,
258
,
258
,
96
,
258
,
258
,
258
,
258
,
/* 1270 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1270 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1280 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1280 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1290 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1290 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
...
@@ -481,12 +481,11 @@ static const YYCODETYPE yy_lookahead[] = {
...
@@ -481,12 +481,11 @@ static const YYCODETYPE yy_lookahead[] = {
/* 1390 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1390 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1400 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1400 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1410 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1410 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1420 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1420 */
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
258
,
/* 1430 */
258
,
258
,
};
};
#define YY_SHIFT_COUNT (426)
#define YY_SHIFT_COUNT (426)
#define YY_SHIFT_MIN (0)
#define YY_SHIFT_MIN (0)
#define YY_SHIFT_MAX (12
41
)
#define YY_SHIFT_MAX (12
35
)
static
const
unsigned
short
int
yy_shift_ofst
[]
=
{
static
const
unsigned
short
int
yy_shift_ofst
[]
=
{
/* 0 */
426
,
212
,
161
,
382
,
382
,
382
,
382
,
421
,
382
,
382
,
/* 0 */
426
,
212
,
161
,
382
,
382
,
382
,
382
,
421
,
382
,
382
,
/* 10 */
151
,
513
,
517
,
444
,
513
,
513
,
513
,
513
,
513
,
513
,
/* 10 */
151
,
513
,
517
,
444
,
513
,
513
,
513
,
513
,
513
,
513
,
...
@@ -503,38 +502,38 @@ static const unsigned short int yy_shift_ofst[] = {
...
@@ -503,38 +502,38 @@ static const unsigned short int yy_shift_ofst[] = {
/* 120 */
657
,
661
,
661
,
706
,
786
,
66
,
343
,
799
,
66
,
706
,
/* 120 */
657
,
661
,
661
,
706
,
786
,
66
,
343
,
799
,
66
,
706
,
/* 130 */
66
,
825
,
17
,
17
,
17
,
17
,
17
,
17
,
17
,
17
,
/* 130 */
66
,
825
,
17
,
17
,
17
,
17
,
17
,
17
,
17
,
17
,
/* 140 */
17
,
17
,
17
,
706
,
825
,
786
,
278
,
343
,
799
,
893
,
/* 140 */
17
,
17
,
17
,
706
,
825
,
786
,
278
,
343
,
799
,
893
,
/* 150 */
769
,
778
,
804
,
769
,
778
,
804
,
782
,
785
,
801
,
809
,
/* 150 */
769
,
778
,
804
,
769
,
778
,
804
,
804
,
784
,
790
,
808
,
/* 160 */
81
7
,
343
,
935
,
844
,
805
,
807
,
816
,
906
,
17
,
778
,
/* 160 */
81
4
,
818
,
343
,
937
,
847
,
805
,
815
,
816
,
908
,
17
,
/* 170 */
804
,
804
,
778
,
804
,
868
,
343
,
799
,
306
,
278
,
343
,
/* 170 */
778
,
804
,
804
,
778
,
804
,
876
,
343
,
799
,
306
,
278
,
/* 180 */
937
,
706
,
278
,
825
,
1269
,
1269
,
1269
,
1269
,
0
,
545
,
/* 180 */
343
,
938
,
706
,
278
,
825
,
1266
,
1266
,
1266
,
1266
,
0
,
/* 190 */
5
77
,
46
,
970
,
16
,
89
,
728
,
406
,
757
,
301
,
301
,
/* 190 */
5
45
,
577
,
46
,
970
,
16
,
89
,
728
,
406
,
757
,
301
,
/* 200 */
301
,
301
,
301
,
301
,
301
,
115
,
288
,
196
,
7
,
7
,
/* 200 */
301
,
301
,
301
,
301
,
301
,
301
,
115
,
288
,
196
,
7
,
/* 210 */
7
,
7
,
374
,
605
,
610
,
701
,
453
,
580
,
632
,
506
,
/* 210 */
7
,
7
,
7
,
374
,
605
,
610
,
701
,
453
,
580
,
632
,
/* 220 */
5
41
,
714
,
715
,
718
,
647
,
590
,
451
,
729
,
74
,
749
,
/* 220 */
5
06
,
541
,
714
,
715
,
718
,
647
,
590
,
451
,
729
,
74
,
/* 230 */
7
58
,
763
,
787
,
795
,
797
,
803
,
639
,
653
,
819
,
823
,
/* 230 */
7
49
,
758
,
763
,
787
,
795
,
797
,
803
,
639
,
653
,
819
,
/* 240 */
82
4
,
826
,
828
,
837
,
751
,
1027
,
947
,
1030
,
1031
,
918
,
/* 240 */
82
3
,
824
,
826
,
828
,
837
,
751
,
1029
,
948
,
1031
,
1032
,
/* 250 */
1033
,
1034
,
1035
,
1036
,
1037
,
1038
,
1018
,
1041
,
1043
,
1044
,
/* 250 */
919
,
1034
,
1035
,
1036
,
1037
,
1038
,
1040
,
1019
,
1043
,
1044
,
/* 260 */
1045
,
1046
,
1047
,
1048
,
10
06
,
1050
,
1003
,
1052
,
1053
,
1016
,
/* 260 */
1045
,
1046
,
1047
,
1048
,
10
49
,
1007
,
1051
,
1004
,
1053
,
1054
,
/* 270 */
101
9
,
1015
,
1059
,
1060
,
1061
,
1062
,
984
,
987
,
1028
,
1029
,
/* 270 */
101
7
,
1022
,
1016
,
1060
,
1061
,
1062
,
1063
,
985
,
988
,
1028
,
/* 280 */
10
49
,
1065
,
1032
,
1039
,
1040
,
1042
,
1051
,
1054
,
1068
,
1057
,
/* 280 */
10
30
,
1050
,
1067
,
1033
,
1039
,
1041
,
1042
,
1052
,
1055
,
1069
,
/* 290 */
10
69
,
1063
,
1055
,
1072
,
1064
,
1058
,
1073
,
1066
,
1074
,
1071
,
/* 290 */
10
56
,
1070
,
1059
,
1057
,
1073
,
1064
,
1065
,
1074
,
1066
,
1075
,
/* 300 */
10
56
,
1075
,
1081
,
961
,
1083
,
1014
,
1067
,
971
,
1007
,
1008
,
/* 300 */
10
72
,
1071
,
1076
,
1082
,
962
,
1084
,
1015
,
1058
,
971
,
1006
,
/* 310 */
954
,
1026
,
1017
,
1070
,
1076
,
1077
,
1078
,
1080
,
1082
,
1079
,
/* 310 */
1009
,
954
,
1026
,
1021
,
1027
,
1068
,
1077
,
1078
,
1080
,
1081
,
/* 320 */
102
0
,
1022
,
1084
,
1023
,
957
,
1085
,
1086
,
1025
,
964
,
1087
,
/* 320 */
102
3
,
1018
,
1083
,
1024
,
958
,
1085
,
1086
,
1020
,
973
,
1079
,
/* 330 */
108
9
,
1088
,
1090
,
960
,
1098
,
1091
,
1092
,
1093
,
1094
,
1095
,
/* 330 */
108
7
,
1088
,
1089
,
964
,
1105
,
1090
,
1091
,
1092
,
1093
,
1094
,
/* 340 */
109
6
,
1103
,
982
,
1097
,
1101
,
1099
,
1104
,
1105
,
1106
,
1108
,
/* 340 */
109
5
,
1108
,
986
,
1096
,
1097
,
1100
,
1101
,
1102
,
1103
,
1106
,
/* 350 */
11
11
,
990
,
1110
,
1118
,
1100
,
995
,
1112
,
1107
,
1102
,
1109
,
/* 350 */
11
07
,
992
,
1109
,
1113
,
1098
,
998
,
1110
,
1104
,
1099
,
1111
,
/* 360 */
11
30
,
1119
,
1131
,
1132
,
1147
,
1148
,
1134
,
1135
,
1150
,
114
4
,
/* 360 */
11
12
,
1115
,
1114
,
1129
,
1148
,
1150
,
1131
,
1132
,
1151
,
113
4
,
/* 370 */
11
42
,
1154
,
1151
,
1153
,
1155
,
1157
,
1158
,
1160
,
1170
,
1024
,
/* 370 */
11
35
,
1153
,
1139
,
1142
,
1154
,
1157
,
1158
,
1160
,
1163
,
1025
,
/* 380 */
112
1
,
1171
,
1172
,
1133
,
1173
,
1156
,
1174
,
1175
,
1177
,
1178
,
/* 380 */
112
2
,
1130
,
1169
,
1133
,
1156
,
1171
,
1172
,
1173
,
1170
,
1174
,
/* 390 */
117
9
,
1180
,
1183
,
1181
,
1185
,
1182
,
1187
,
1193
,
1194
,
1199
,
/* 390 */
117
5
,
1177
,
1181
,
1178
,
1180
,
1179
,
1182
,
1185
,
1186
,
1192
,
/* 400 */
1
204
,
1205
,
1186
,
1208
,
1209
,
1213
,
1214
,
1215
,
1216
,
1217
,
/* 400 */
1
193
,
1194
,
1189
,
1196
,
1198
,
1199
,
1201
,
1207
,
1209
,
1210
,
/* 410 */
121
8
,
1221
,
1190
,
1222
,
1202
,
1191
,
1233
,
1225
,
1227
,
123
5
,
/* 410 */
121
2
,
1213
,
1187
,
1214
,
1202
,
1218
,
1190
,
1219
,
1221
,
120
5
,
/* 420 */
123
6
,
1188
,
1229
,
1189
,
1226
,
1237
,
1241
,
/* 420 */
123
5
,
1188
,
1228
,
1231
,
1232
,
1234
,
1224
,
};
};
#define YY_REDUCE_COUNT (18
7
)
#define YY_REDUCE_COUNT (18
8
)
#define YY_REDUCE_MIN (-217)
#define YY_REDUCE_MIN (-217)
#define YY_REDUCE_MAX (86
2
)
#define YY_REDUCE_MAX (86
3
)
static
const
short
yy_reduce_ofst
[]
=
{
static
const
short
yy_reduce_ofst
[]
=
{
/* 0 */
-
129
,
-
6
,
49
,
78
,
126
,
155
,
190
,
219
,
276
,
299
,
/* 0 */
-
129
,
-
6
,
49
,
78
,
126
,
155
,
190
,
219
,
276
,
299
,
/* 10 */
135
,
375
,
398
,
434
,
492
,
-
80
,
497
,
515
,
520
,
562
,
/* 10 */
135
,
375
,
398
,
434
,
492
,
-
80
,
497
,
515
,
520
,
562
,
...
@@ -551,10 +550,10 @@ static const short yy_reduce_ofst[] = {
...
@@ -551,10 +550,10 @@ static const short yy_reduce_ofst[] = {
/* 120 */
589
,
592
,
593
,
623
,
599
,
643
,
620
,
631
,
650
,
666
,
/* 120 */
589
,
592
,
593
,
623
,
599
,
643
,
620
,
631
,
650
,
666
,
/* 130 */
668
,
676
,
665
,
673
,
679
,
683
,
686
,
689
,
690
,
693
,
/* 130 */
668
,
676
,
665
,
673
,
679
,
683
,
686
,
689
,
690
,
693
,
/* 140 */
699
,
707
,
710
,
680
,
694
,
692
,
733
,
717
,
696
,
705
,
/* 140 */
699
,
707
,
710
,
680
,
694
,
692
,
733
,
717
,
696
,
705
,
/* 150 */
677
,
716
,
719
,
682
,
722
,
724
,
695
,
700
,
697
,
723
,
/* 150 */
677
,
716
,
719
,
682
,
722
,
724
,
727
,
695
,
700
,
697
,
/* 160 */
471
,
761
,
742
,
734
,
709
,
712
,
720
,
755
,
476
,
771
,
/* 160 */
723
,
471
,
762
,
743
,
736
,
709
,
712
,
725
,
756
,
476
,
/* 170 */
77
3
,
775
,
779
,
783
,
789
,
806
,
792
,
818
,
827
,
811
,
/* 170 */
77
2
,
775
,
779
,
782
,
780
,
791
,
806
,
794
,
822
,
829
,
/* 180 */
8
21
,
836
,
841
,
849
,
842
,
843
,
852
,
862
,
/* 180 */
8
17
,
833
,
835
,
841
,
849
,
843
,
845
,
853
,
863
,
};
};
static
const
YYACTIONTYPE
yy_default
[]
=
{
static
const
YYACTIONTYPE
yy_default
[]
=
{
/* 0 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 0 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
...
@@ -572,23 +571,23 @@ static const YYACTIONTYPE yy_default[] = {
...
@@ -572,23 +571,23 @@ static const YYACTIONTYPE yy_default[] = {
/* 120 */
1166
,
1163
,
1163
,
996
,
996
,
1049
,
996
,
996
,
1049
,
996
,
/* 120 */
1166
,
1163
,
1163
,
996
,
996
,
1049
,
996
,
996
,
1049
,
996
,
/* 130 */
1049
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 130 */
1049
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 140 */
996
,
996
,
996
,
996
,
996
,
996
,
1047
,
996
,
996
,
996
,
/* 140 */
996
,
996
,
996
,
996
,
996
,
996
,
1047
,
996
,
996
,
996
,
/* 150 */
1297
,
1295
,
996
,
1297
,
1295
,
996
,
1309
,
1305
,
1288
,
1286
,
/* 150 */
1297
,
1295
,
996
,
1297
,
1295
,
996
,
996
,
1309
,
1305
,
1288
,
/* 160 */
12
72
,
996
,
996
,
996
,
1333
,
1321
,
1317
,
996
,
996
,
1295
,
/* 160 */
12
86
,
1272
,
996
,
996
,
996
,
1333
,
1321
,
1317
,
996
,
996
,
/* 170 */
996
,
996
,
1295
,
996
,
1174
,
996
,
996
,
996
,
1047
,
996
,
/* 170 */
1295
,
996
,
996
,
1295
,
996
,
1174
,
996
,
996
,
996
,
1047
,
/* 180 */
1101
,
996
,
1047
,
996
,
1135
,
1135
,
1050
,
1001
,
996
,
996
,
/* 180 */
996
,
1101
,
996
,
1047
,
996
,
1135
,
1135
,
1050
,
1001
,
996
,
/* 190 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
1227
,
1308
,
/* 190 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
1227
,
/* 200 */
130
7
,
1226
,
1232
,
1231
,
1230
,
996
,
996
,
996
,
1221
,
1222
,
/* 200 */
130
8
,
1307
,
1226
,
1232
,
1231
,
1230
,
996
,
996
,
996
,
1221
,
/* 210 */
122
0
,
1219
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 210 */
122
2
,
1220
,
1219
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 220 */
996
,
996
,
996
,
1256
,
996
,
1318
,
1322
,
996
,
996
,
996
,
/* 220 */
996
,
996
,
996
,
996
,
1256
,
996
,
1318
,
1322
,
996
,
996
,
/* 230 */
1206
,
99
6
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 230 */
996
,
120
6
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 240 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 240 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 250 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 250 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 260 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 260 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 270 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 270 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 280 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 280 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 290 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 290 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 300 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
1279
,
128
9
,
/* 300 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
127
9
,
/* 310 */
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 310 */
1289
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 320 */
996
,
1206
,
996
,
1306
,
996
,
1265
,
1261
,
996
,
996
,
1257
,
/* 320 */
996
,
1206
,
996
,
1306
,
996
,
1265
,
1261
,
996
,
996
,
1257
,
/* 330 */
996
,
996
,
1316
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 330 */
996
,
996
,
1316
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 340 */
996
,
1251
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
/* 340 */
996
,
1251
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
996
,
...
@@ -1263,7 +1262,7 @@ static const char *const yyRuleName[] = {
...
@@ -1263,7 +1262,7 @@ static const char *const yyRuleName[] = {
/* 289 */
"partition_by_clause_opt ::="
,
/* 289 */
"partition_by_clause_opt ::="
,
/* 290 */
"partition_by_clause_opt ::= PARTITION BY expression_list"
,
/* 290 */
"partition_by_clause_opt ::= PARTITION BY expression_list"
,
/* 291 */
"twindow_clause_opt ::="
,
/* 291 */
"twindow_clause_opt ::="
,
/* 292 */
"twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA
NK_INTEGER
NK_RP"
,
/* 292 */
"twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA
duration_literal
NK_RP"
,
/* 293 */
"twindow_clause_opt ::= STATE_WINDOW NK_LP column_reference NK_RP"
,
/* 293 */
"twindow_clause_opt ::= STATE_WINDOW NK_LP column_reference NK_RP"
,
/* 294 */
"twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_RP sliding_opt fill_opt"
,
/* 294 */
"twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_RP sliding_opt fill_opt"
,
/* 295 */
"twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt fill_opt"
,
/* 295 */
"twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt fill_opt"
,
...
@@ -2163,7 +2162,7 @@ static const struct {
...
@@ -2163,7 +2162,7 @@ static const struct {
{
240
,
0
},
/* (289) partition_by_clause_opt ::= */
{
240
,
0
},
/* (289) partition_by_clause_opt ::= */
{
240
,
-
3
},
/* (290) partition_by_clause_opt ::= PARTITION BY expression_list */
{
240
,
-
3
},
/* (290) partition_by_clause_opt ::= PARTITION BY expression_list */
{
241
,
0
},
/* (291) twindow_clause_opt ::= */
{
241
,
0
},
/* (291) twindow_clause_opt ::= */
{
241
,
-
6
},
/* (292) twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA
NK_INTEGER
NK_RP */
{
241
,
-
6
},
/* (292) twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA
duration_literal
NK_RP */
{
241
,
-
4
},
/* (293) twindow_clause_opt ::= STATE_WINDOW NK_LP column_reference NK_RP */
{
241
,
-
4
},
/* (293) twindow_clause_opt ::= STATE_WINDOW NK_LP column_reference NK_RP */
{
241
,
-
6
},
/* (294) twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_RP sliding_opt fill_opt */
{
241
,
-
6
},
/* (294) twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_RP sliding_opt fill_opt */
{
241
,
-
8
},
/* (295) twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt fill_opt */
{
241
,
-
8
},
/* (295) twindow_clause_opt ::= INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt fill_opt */
...
@@ -3230,8 +3229,8 @@ static YYACTIONTYPE yy_reduce(
...
@@ -3230,8 +3229,8 @@ static YYACTIONTYPE yy_reduce(
case
317
:
/* order_by_clause_opt ::= ORDER BY sort_specification_list */
yytestcase
(
yyruleno
==
317
);
case
317
:
/* order_by_clause_opt ::= ORDER BY sort_specification_list */
yytestcase
(
yyruleno
==
317
);
{
yymsp
[
-
2
].
minor
.
yy136
=
yymsp
[
0
].
minor
.
yy136
;
}
{
yymsp
[
-
2
].
minor
.
yy136
=
yymsp
[
0
].
minor
.
yy136
;
}
break
;
break
;
case
292
:
/* twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA
NK_INTEGER
NK_RP */
case
292
:
/* twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA
duration_literal
NK_RP */
{
yymsp
[
-
5
].
minor
.
yy140
=
createSessionWindowNode
(
pCxt
,
releaseRawExprNode
(
pCxt
,
yymsp
[
-
3
].
minor
.
yy140
),
&
yymsp
[
-
1
].
minor
.
yy0
);
}
{
yymsp
[
-
5
].
minor
.
yy140
=
createSessionWindowNode
(
pCxt
,
releaseRawExprNode
(
pCxt
,
yymsp
[
-
3
].
minor
.
yy140
),
releaseRawExprNode
(
pCxt
,
yymsp
[
-
1
].
minor
.
yy140
)
);
}
break
;
break
;
case
293
:
/* twindow_clause_opt ::= STATE_WINDOW NK_LP column_reference NK_RP */
case
293
:
/* twindow_clause_opt ::= STATE_WINDOW NK_LP column_reference NK_RP */
{
yymsp
[
-
3
].
minor
.
yy140
=
createStateWindowNode
(
pCxt
,
releaseRawExprNode
(
pCxt
,
yymsp
[
-
1
].
minor
.
yy140
));
}
{
yymsp
[
-
3
].
minor
.
yy140
=
createStateWindowNode
(
pCxt
,
releaseRawExprNode
(
pCxt
,
yymsp
[
-
1
].
minor
.
yy140
));
}
...
...
source/libs/parser/test/parserAstTest.cpp
浏览文件 @
c3e098d7
...
@@ -44,6 +44,9 @@ protected:
...
@@ -44,6 +44,9 @@ protected:
query_
=
nullptr
;
query_
=
nullptr
;
bool
res
=
runImpl
(
parseCode
,
translateCode
);
bool
res
=
runImpl
(
parseCode
,
translateCode
);
qDestroyQuery
(
query_
);
qDestroyQuery
(
query_
);
if
(
!
res
)
{
dump
();
}
return
res
;
return
res
;
}
}
...
@@ -53,26 +56,40 @@ private:
...
@@ -53,26 +56,40 @@ private:
bool
runImpl
(
int32_t
parseCode
,
int32_t
translateCode
)
{
bool
runImpl
(
int32_t
parseCode
,
int32_t
translateCode
)
{
int32_t
code
=
doParse
(
&
cxt_
,
&
query_
);
int32_t
code
=
doParse
(
&
cxt_
,
&
query_
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] parser code:"
<<
tstrerror
(
code
)
<<
", msg:"
<<
errMagBuf_
<<
endl
;
parseErrStr_
=
string
(
"code:"
)
+
tstrerror
(
code
)
+
string
(
", msg:"
)
+
errMagBuf_
;
return
(
TSDB_CODE_SUCCESS
!
=
parseCode
);
return
(
terrno
=
=
parseCode
);
}
}
if
(
TSDB_CODE_SUCCESS
!=
parseCode
)
{
if
(
TSDB_CODE_SUCCESS
!=
parseCode
)
{
return
false
;
return
false
;
}
}
string
parserStr
=
toString
(
query_
->
pRoot
);
parsedAstStr_
=
toString
(
query_
->
pRoot
);
code
=
doTranslate
(
&
cxt_
,
query_
);
code
=
doTranslate
(
&
cxt_
,
query_
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] translate code:"
<<
code
<<
", "
<<
translateCode
<<
", msg:"
<<
errMagBuf_
<<
endl
;
translateErrStr_
=
string
(
"code:"
)
+
tstrerror
(
code
)
+
string
(
", msg:"
)
+
errMagBuf_
;
return
(
code
==
translateCode
);
return
(
terrno
==
translateCode
);
}
}
cout
<<
"input sql : ["
<<
cxt_
.
pSql
<<
"]"
<<
endl
;
translatedAstStr_
=
toString
(
query_
->
pRoot
);
cout
<<
"parser output: "
<<
endl
;
cout
<<
parserStr
<<
endl
;
cout
<<
"translate output: "
<<
endl
;
cout
<<
toString
(
query_
->
pRoot
)
<<
endl
;
return
(
TSDB_CODE_SUCCESS
==
translateCode
);
return
(
TSDB_CODE_SUCCESS
==
translateCode
);
}
}
void
dump
()
{
cout
<<
"input sql : ["
<<
cxt_
.
pSql
<<
"]"
<<
endl
;
if
(
!
parseErrStr_
.
empty
())
{
cout
<<
"parse error: "
<<
parseErrStr_
<<
endl
;
}
if
(
!
parsedAstStr_
.
empty
())
{
cout
<<
"parse output: "
<<
endl
;
cout
<<
parsedAstStr_
<<
endl
;
}
if
(
!
translateErrStr_
.
empty
())
{
cout
<<
"translate error: "
<<
translateErrStr_
<<
endl
;
}
if
(
!
translatedAstStr_
.
empty
())
{
cout
<<
"translate output: "
<<
endl
;
cout
<<
translatedAstStr_
<<
endl
;
}
}
string
toString
(
const
SNode
*
pRoot
,
bool
format
=
false
)
{
string
toString
(
const
SNode
*
pRoot
,
bool
format
=
false
)
{
char
*
pStr
=
NULL
;
char
*
pStr
=
NULL
;
int32_t
len
=
0
;
int32_t
len
=
0
;
...
@@ -91,6 +108,10 @@ private:
...
@@ -91,6 +108,10 @@ private:
memset
(
errMagBuf_
,
0
,
max_err_len
);
memset
(
errMagBuf_
,
0
,
max_err_len
);
cxt_
.
pMsg
=
errMagBuf_
;
cxt_
.
pMsg
=
errMagBuf_
;
cxt_
.
msgLen
=
max_err_len
;
cxt_
.
msgLen
=
max_err_len
;
parseErrStr_
.
clear
();
parsedAstStr_
.
clear
();
translateErrStr_
.
clear
();
translatedAstStr_
.
clear
();
}
}
string
acctId_
;
string
acctId_
;
...
@@ -99,8 +120,50 @@ private:
...
@@ -99,8 +120,50 @@ private:
string
sqlBuf_
;
string
sqlBuf_
;
SParseContext
cxt_
;
SParseContext
cxt_
;
SQuery
*
query_
;
SQuery
*
query_
;
string
parseErrStr_
;
string
parsedAstStr_
;
string
translateErrStr_
;
string
translatedAstStr_
;
};
};
TEST_F
(
ParserTest
,
createAccount
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"create account ac_wxy pass '123456'"
);
ASSERT_TRUE
(
run
(
TSDB_CODE_PAR_EXPRIE_STATEMENT
));
}
TEST_F
(
ParserTest
,
alterAccount
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"alter account ac_wxy pass '123456'"
);
ASSERT_TRUE
(
run
(
TSDB_CODE_PAR_EXPRIE_STATEMENT
));
}
TEST_F
(
ParserTest
,
createUser
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"create user wxy pass '123456'"
);
ASSERT_TRUE
(
run
());
}
TEST_F
(
ParserTest
,
alterUser
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"alter user wxy pass '123456'"
);
ASSERT_TRUE
(
run
());
bind
(
"alter user wxy privilege 'write'"
);
ASSERT_TRUE
(
run
());
}
TEST_F
(
ParserTest
,
dropUser
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"drop user wxy"
);
ASSERT_TRUE
(
run
());
}
TEST_F
(
ParserTest
,
selectSimple
)
{
TEST_F
(
ParserTest
,
selectSimple
)
{
setDatabase
(
"root"
,
"test"
);
setDatabase
(
"root"
,
"test"
);
...
@@ -295,12 +358,6 @@ TEST_F(ParserTest, selectSemanticError) {
...
@@ -295,12 +358,6 @@ TEST_F(ParserTest, selectSemanticError) {
ASSERT_TRUE
(
run
(
TSDB_CODE_SUCCESS
,
TSDB_CODE_PAR_NOT_SELECTED_EXPRESSION
));
ASSERT_TRUE
(
run
(
TSDB_CODE_SUCCESS
,
TSDB_CODE_PAR_NOT_SELECTED_EXPRESSION
));
}
}
TEST_F
(
ParserTest
,
createUser
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"create user wxy pass '123456'"
);
ASSERT_TRUE
(
run
());
}
TEST_F
(
ParserTest
,
showUsers
)
{
TEST_F
(
ParserTest
,
showUsers
)
{
setDatabase
(
"root"
,
"test"
);
setDatabase
(
"root"
,
"test"
);
...
@@ -309,12 +366,7 @@ TEST_F(ParserTest, showUsers) {
...
@@ -309,12 +366,7 @@ TEST_F(ParserTest, showUsers) {
ASSERT_TRUE
(
run
());
ASSERT_TRUE
(
run
());
}
}
TEST_F
(
ParserTest
,
alterAccount
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"alter account ac_wxy pass '123456'"
);
ASSERT_TRUE
(
run
(
TSDB_CODE_PAR_EXPRIE_STATEMENT
));
}
TEST_F
(
ParserTest
,
createDnode
)
{
TEST_F
(
ParserTest
,
createDnode
)
{
setDatabase
(
"root"
,
"test"
);
setDatabase
(
"root"
,
"test"
);
...
...
source/libs/planner/inc/planInt.h
浏览文件 @
c3e098d7
...
@@ -56,9 +56,10 @@ extern "C" {
...
@@ -56,9 +56,10 @@ extern "C" {
#define planTrace(param, ...) qTrace("PLAN: " param, __VA_ARGS__)
#define planTrace(param, ...) qTrace("PLAN: " param, __VA_ARGS__)
int32_t
createLogicPlan
(
SPlanContext
*
pCxt
,
SLogicNode
**
pLogicNode
);
int32_t
createLogicPlan
(
SPlanContext
*
pCxt
,
SLogicNode
**
pLogicNode
);
int32_t
optimize
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
);
int32_t
optimizeLogicPlan
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
);
int32_t
applySplitRule
(
SSubLogicPlan
*
pSubplan
);
int32_t
splitLogicPlan
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
,
SLogicSubplan
**
pLogicSubplan
);
int32_t
createPhysiPlan
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
,
SQueryPlan
**
pPlan
,
SArray
*
pExecNodeList
);
int32_t
scaleOutLogicPlan
(
SPlanContext
*
pCxt
,
SLogicSubplan
*
pLogicSubplan
,
SQueryLogicPlan
**
pLogicPlan
);
int32_t
createPhysiPlan
(
SPlanContext
*
pCxt
,
SQueryLogicPlan
*
pLogicPlan
,
SQueryPlan
**
pPlan
,
SArray
*
pExecNodeList
);
#ifdef __cplusplus
#ifdef __cplusplus
}
}
...
...
source/libs/planner/src/planLogicCreater.c
浏览文件 @
c3e098d7
...
@@ -411,6 +411,38 @@ static int32_t createAggLogicNode(SLogicPlanContext* pCxt, SSelectStmt* pSelect,
...
@@ -411,6 +411,38 @@ static int32_t createAggLogicNode(SLogicPlanContext* pCxt, SSelectStmt* pSelect,
return
code
;
return
code
;
}
}
static
int32_t
createWindowLogicNodeFinalize
(
SLogicPlanContext
*
pCxt
,
SSelectStmt
*
pSelect
,
SWindowLogicNode
*
pWindow
,
SLogicNode
**
pLogicNode
)
{
int32_t
code
=
nodesCollectFuncs
(
pSelect
,
fmIsAggFunc
,
&
pWindow
->
pFuncs
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
rewriteExpr
(
pWindow
->
pFuncs
,
pSelect
,
SQL_CLAUSE_WINDOW
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
createColumnByRewriteExps
(
pCxt
,
pWindow
->
pFuncs
,
&
pWindow
->
node
.
pTargets
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pLogicNode
=
(
SLogicNode
*
)
pWindow
;
}
else
{
nodesDestroyNode
(
pWindow
);
}
return
code
;
}
static
int32_t
createWindowLogicNodeBySession
(
SLogicPlanContext
*
pCxt
,
SSessionWindowNode
*
pSession
,
SSelectStmt
*
pSelect
,
SLogicNode
**
pLogicNode
)
{
SWindowLogicNode
*
pWindow
=
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN_WINDOW
);
if
(
NULL
==
pWindow
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pWindow
->
winType
=
WINDOW_TYPE_SESSION
;
pWindow
->
sessionGap
=
((
SValueNode
*
)
pSession
->
pGap
)
->
datum
.
i
;
return
createWindowLogicNodeFinalize
(
pCxt
,
pSelect
,
pWindow
,
pLogicNode
);
}
static
int32_t
createWindowLogicNodeByInterval
(
SLogicPlanContext
*
pCxt
,
SIntervalWindowNode
*
pInterval
,
SSelectStmt
*
pSelect
,
SLogicNode
**
pLogicNode
)
{
static
int32_t
createWindowLogicNodeByInterval
(
SLogicPlanContext
*
pCxt
,
SIntervalWindowNode
*
pInterval
,
SSelectStmt
*
pSelect
,
SLogicNode
**
pLogicNode
)
{
SWindowLogicNode
*
pWindow
=
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN_WINDOW
);
SWindowLogicNode
*
pWindow
=
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN_WINDOW
);
if
(
NULL
==
pWindow
)
{
if
(
NULL
==
pWindow
)
{
...
@@ -424,34 +456,15 @@ static int32_t createWindowLogicNodeByInterval(SLogicPlanContext* pCxt, SInterva
...
@@ -424,34 +456,15 @@ static int32_t createWindowLogicNodeByInterval(SLogicPlanContext* pCxt, SInterva
pWindow
->
sliding
=
(
NULL
!=
pInterval
->
pSliding
?
((
SValueNode
*
)
pInterval
->
pSliding
)
->
datum
.
i
:
pWindow
->
interval
);
pWindow
->
sliding
=
(
NULL
!=
pInterval
->
pSliding
?
((
SValueNode
*
)
pInterval
->
pSliding
)
->
datum
.
i
:
pWindow
->
interval
);
pWindow
->
slidingUnit
=
(
NULL
!=
pInterval
->
pSliding
?
((
SValueNode
*
)
pInterval
->
pSliding
)
->
unit
:
pWindow
->
intervalUnit
);
pWindow
->
slidingUnit
=
(
NULL
!=
pInterval
->
pSliding
?
((
SValueNode
*
)
pInterval
->
pSliding
)
->
unit
:
pWindow
->
intervalUnit
);
int32_t
code
=
TSDB_CODE_SUCCESS
;
if
(
NULL
!=
pInterval
->
pFill
)
{
if
(
NULL
!=
pInterval
->
pFill
)
{
pWindow
->
pFill
=
nodesCloneNode
(
pInterval
->
pFill
);
pWindow
->
pFill
=
nodesCloneNode
(
pInterval
->
pFill
);
if
(
NULL
==
pWindow
->
pFill
)
{
if
(
NULL
==
pWindow
->
pFill
)
{
code
=
TSDB_CODE_OUT_OF_MEMORY
;
nodesDestroyNode
(
pWindow
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
return
createWindowLogicNodeFinalize
(
pCxt
,
pSelect
,
pWindow
,
pLogicNode
);
code
=
nodesCollectFuncs
(
pSelect
,
fmIsAggFunc
,
&
pWindow
->
pFuncs
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
rewriteExpr
(
pWindow
->
pFuncs
,
pSelect
,
SQL_CLAUSE_WINDOW
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
createColumnByRewriteExps
(
pCxt
,
pWindow
->
pFuncs
,
&
pWindow
->
node
.
pTargets
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pLogicNode
=
(
SLogicNode
*
)
pWindow
;
}
else
{
nodesDestroyNode
(
pWindow
);
}
return
code
;
}
}
static
int32_t
createWindowLogicNode
(
SLogicPlanContext
*
pCxt
,
SSelectStmt
*
pSelect
,
SLogicNode
**
pLogicNode
)
{
static
int32_t
createWindowLogicNode
(
SLogicPlanContext
*
pCxt
,
SSelectStmt
*
pSelect
,
SLogicNode
**
pLogicNode
)
{
...
@@ -460,8 +473,10 @@ static int32_t createWindowLogicNode(SLogicPlanContext* pCxt, SSelectStmt* pSele
...
@@ -460,8 +473,10 @@ static int32_t createWindowLogicNode(SLogicPlanContext* pCxt, SSelectStmt* pSele
}
}
switch
(
nodeType
(
pSelect
->
pWindow
))
{
switch
(
nodeType
(
pSelect
->
pWindow
))
{
case
QUERY_NODE_SESSION_WINDOW
:
return
createWindowLogicNodeBySession
(
pCxt
,
(
SSessionWindowNode
*
)
pSelect
->
pWindow
,
pSelect
,
pLogicNode
);
case
QUERY_NODE_INTERVAL_WINDOW
:
case
QUERY_NODE_INTERVAL_WINDOW
:
return
createWindowLogicNodeByInterval
(
pCxt
,
(
SIntervalWindowNode
*
)
pSelect
->
pWindow
,
pSelect
,
pLogicNode
);
return
createWindowLogicNodeByInterval
(
pCxt
,
(
SIntervalWindowNode
*
)
pSelect
->
pWindow
,
pSelect
,
pLogicNode
);
default:
default:
break
;
break
;
}
}
...
...
source/libs/planner/src/planOptimizer.c
0 → 100644
浏览文件 @
c3e098d7
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "planInt.h"
int32_t
optimizeLogicPlan
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
)
{
return
TSDB_CODE_SUCCESS
;
}
source/libs/planner/src/planPhysiCreater.c
浏览文件 @
c3e098d7
...
@@ -28,7 +28,6 @@ typedef struct SPhysiPlanContext {
...
@@ -28,7 +28,6 @@ typedef struct SPhysiPlanContext {
int16_t
nextDataBlockId
;
int16_t
nextDataBlockId
;
SArray
*
pLocationHelper
;
SArray
*
pLocationHelper
;
SArray
*
pExecNodeList
;
SArray
*
pExecNodeList
;
int32_t
subplanId
;
}
SPhysiPlanContext
;
}
SPhysiPlanContext
;
static
int32_t
getSlotKey
(
SNode
*
pNode
,
char
*
pKey
)
{
static
int32_t
getSlotKey
(
SNode
*
pNode
,
char
*
pKey
)
{
...
@@ -124,35 +123,52 @@ static EDealRes doSetSlotId(SNode* pNode, void* pContext) {
...
@@ -124,35 +123,52 @@ static EDealRes doSetSlotId(SNode* pNode, void* pContext) {
return
DEAL_RES_CONTINUE
;
return
DEAL_RES_CONTINUE
;
}
}
static
SNode
*
setNodeSlotId
(
SPhysiPlanContext
*
pCxt
,
int16_t
leftDataBlockId
,
int16_t
rightDataBlockId
,
SNode
*
pNode
)
{
static
int32_t
setNodeSlotId
(
SPhysiPlanContext
*
pCxt
,
int16_t
leftDataBlockId
,
int16_t
rightDataBlockId
,
SNode
*
pNode
,
SNode
**
pOutput
)
{
SNode
*
pRes
=
nodesCloneNode
(
pNode
);
SNode
*
pRes
=
nodesCloneNode
(
pNode
);
CHECK_ALLOC
(
pRes
,
NULL
);
if
(
NULL
==
pRes
)
{
SSetSlotIdCxt
cxt
=
{
.
errCode
=
TSDB_CODE_SUCCESS
,
.
pLeftHash
=
taosArrayGetP
(
pCxt
->
pLocationHelper
,
leftDataBlockId
),
return
TSDB_CODE_OUT_OF_MEMORY
;
.
pRightHash
=
(
rightDataBlockId
<
0
?
NULL
:
taosArrayGetP
(
pCxt
->
pLocationHelper
,
rightDataBlockId
))
};
}
SSetSlotIdCxt
cxt
=
{
.
errCode
=
TSDB_CODE_SUCCESS
,
.
pLeftHash
=
taosArrayGetP
(
pCxt
->
pLocationHelper
,
leftDataBlockId
),
.
pRightHash
=
(
rightDataBlockId
<
0
?
NULL
:
taosArrayGetP
(
pCxt
->
pLocationHelper
,
rightDataBlockId
))
};
nodesWalkNode
(
pRes
,
doSetSlotId
,
&
cxt
);
nodesWalkNode
(
pRes
,
doSetSlotId
,
&
cxt
);
if
(
TSDB_CODE_SUCCESS
!=
cxt
.
errCode
)
{
if
(
TSDB_CODE_SUCCESS
!=
cxt
.
errCode
)
{
nodesDestroyNode
(
pRes
);
nodesDestroyNode
(
pRes
);
return
NULL
;
return
cxt
.
errCode
;
}
}
return
pRes
;
*
pOutput
=
pRes
;
return
TSDB_CODE_SUCCESS
;
}
}
static
SNodeList
*
setListSlotId
(
SPhysiPlanContext
*
pCxt
,
int16_t
leftDataBlockId
,
int16_t
rightDataBlockId
,
SNodeList
*
pLis
t
)
{
static
int32_t
setListSlotId
(
SPhysiPlanContext
*
pCxt
,
int16_t
leftDataBlockId
,
int16_t
rightDataBlockId
,
SNodeList
*
pList
,
SNodeList
**
pOutpu
t
)
{
SNodeList
*
pRes
=
nodesCloneList
(
pList
);
SNodeList
*
pRes
=
nodesCloneList
(
pList
);
CHECK_ALLOC
(
pRes
,
NULL
);
if
(
NULL
==
pRes
)
{
SSetSlotIdCxt
cxt
=
{
.
errCode
=
TSDB_CODE_SUCCESS
,
.
pLeftHash
=
taosArrayGetP
(
pCxt
->
pLocationHelper
,
leftDataBlockId
),
return
TSDB_CODE_OUT_OF_MEMORY
;
.
pRightHash
=
(
rightDataBlockId
<
0
?
NULL
:
taosArrayGetP
(
pCxt
->
pLocationHelper
,
rightDataBlockId
))
};
}
SSetSlotIdCxt
cxt
=
{
.
errCode
=
TSDB_CODE_SUCCESS
,
.
pLeftHash
=
taosArrayGetP
(
pCxt
->
pLocationHelper
,
leftDataBlockId
),
.
pRightHash
=
(
rightDataBlockId
<
0
?
NULL
:
taosArrayGetP
(
pCxt
->
pLocationHelper
,
rightDataBlockId
))
};
nodesWalkList
(
pRes
,
doSetSlotId
,
&
cxt
);
nodesWalkList
(
pRes
,
doSetSlotId
,
&
cxt
);
if
(
TSDB_CODE_SUCCESS
!=
cxt
.
errCode
)
{
if
(
TSDB_CODE_SUCCESS
!=
cxt
.
errCode
)
{
nodesDestroyList
(
pRes
);
nodesDestroyList
(
pRes
);
return
NULL
;
return
cxt
.
errCode
;
}
}
return
pRes
;
*
pOutput
=
pRes
;
return
TSDB_CODE_SUCCESS
;
}
}
static
SPhysiNode
*
makePhysiNode
(
SPhysiPlanContext
*
pCxt
,
ENodeType
type
)
{
static
SPhysiNode
*
makePhysiNode
(
SPhysiPlanContext
*
pCxt
,
ENodeType
type
)
{
SPhysiNode
*
pPhysiNode
=
(
SPhysiNode
*
)
nodesMakeNode
(
type
);
SPhysiNode
*
pPhysiNode
=
(
SPhysiNode
*
)
nodesMakeNode
(
type
);
CHECK_ALLOC
(
pPhysiNode
,
NULL
);
if
(
NULL
==
pPhysiNode
)
{
return
NULL
;
}
pPhysiNode
->
pOutputDataBlockDesc
=
nodesMakeNode
(
QUERY_NODE_DATABLOCK_DESC
);
pPhysiNode
->
pOutputDataBlockDesc
=
nodesMakeNode
(
QUERY_NODE_DATABLOCK_DESC
);
if
(
NULL
==
pPhysiNode
->
pOutputDataBlockDesc
)
{
if
(
NULL
==
pPhysiNode
->
pOutputDataBlockDesc
)
{
nodesDestroyNode
(
pPhysiNode
);
nodesDestroyNode
(
pPhysiNode
);
...
@@ -165,8 +181,7 @@ static SPhysiNode* makePhysiNode(SPhysiPlanContext* pCxt, ENodeType type) {
...
@@ -165,8 +181,7 @@ static SPhysiNode* makePhysiNode(SPhysiPlanContext* pCxt, ENodeType type) {
static
int32_t
setConditionsSlotId
(
SPhysiPlanContext
*
pCxt
,
const
SLogicNode
*
pLogicNode
,
SPhysiNode
*
pPhysiNode
)
{
static
int32_t
setConditionsSlotId
(
SPhysiPlanContext
*
pCxt
,
const
SLogicNode
*
pLogicNode
,
SPhysiNode
*
pPhysiNode
)
{
if
(
NULL
!=
pLogicNode
->
pConditions
)
{
if
(
NULL
!=
pLogicNode
->
pConditions
)
{
pPhysiNode
->
pConditions
=
setNodeSlotId
(
pCxt
,
pPhysiNode
->
pOutputDataBlockDesc
->
dataBlockId
,
-
1
,
pLogicNode
->
pConditions
);
return
setNodeSlotId
(
pCxt
,
pPhysiNode
->
pOutputDataBlockDesc
->
dataBlockId
,
-
1
,
pLogicNode
->
pConditions
,
&
pPhysiNode
->
pConditions
);
CHECK_ALLOC
(
pPhysiNode
->
pConditions
,
TSDB_CODE_OUT_OF_MEMORY
);
}
}
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
...
@@ -223,24 +238,34 @@ static int32_t createScanCols(SPhysiPlanContext* pCxt, SScanPhysiNode* pScanPhys
...
@@ -223,24 +238,34 @@ static int32_t createScanCols(SPhysiPlanContext* pCxt, SScanPhysiNode* pScanPhys
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
static
int32_t
initScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SScanLogicNode
*
pScanLogicNode
,
SScanPhysiNode
*
pScanPhysiNode
)
{
static
int32_t
createScanPhysiNodeFinalize
(
SPhysiPlanContext
*
pCxt
,
SScanLogicNode
*
pScanLogicNode
,
SScanPhysiNode
*
pScanPhysiNode
,
SPhysiNode
**
pPhyNode
)
{
CHECK_CODE
(
createScanCols
(
pCxt
,
pScanPhysiNode
,
pScanLogicNode
->
pScanCols
),
TSDB_CODE_OUT_OF_MEMORY
);
int32_t
code
=
createScanCols
(
pCxt
,
pScanPhysiNode
,
pScanLogicNode
->
pScanCols
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
// Data block describe also needs to be set without scanning column, such as SELECT COUNT(*) FROM t
// Data block describe also needs to be set without scanning column, such as SELECT COUNT(*) FROM t
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pScanPhysiNode
->
pScanCols
,
pScanPhysiNode
->
node
.
pOutputDataBlockDesc
),
TSDB_CODE_OUT_OF_MEMORY
);
code
=
addDataBlockDesc
(
pCxt
,
pScanPhysiNode
->
pScanCols
,
pScanPhysiNode
->
node
.
pOutputDataBlockDesc
);
}
CHECK_CODE
(
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pScanLogicNode
,
(
SPhysiNode
*
)
pScanPhysiNode
),
TSDB_CODE_OUT_OF_MEMORY
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pScanLogicNode
,
(
SPhysiNode
*
)
pScanPhysiNode
);
CHECK_CODE
(
setSlotOutput
(
pCxt
,
pScanLogicNode
->
node
.
pTargets
,
pScanPhysiNode
->
node
.
pOutputDataBlockDesc
),
TSDB_CODE_OUT_OF_MEMORY
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setSlotOutput
(
pCxt
,
pScanLogicNode
->
node
.
pTargets
,
pScanPhysiNode
->
node
.
pOutputDataBlockDesc
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
pScanPhysiNode
->
uid
=
pScanLogicNode
->
pMeta
->
uid
;
pScanPhysiNode
->
tableType
=
pScanLogicNode
->
pMeta
->
tableType
;
pScanPhysiNode
->
order
=
TSDB_ORDER_ASC
;
pScanPhysiNode
->
count
=
1
;
pScanPhysiNode
->
reverse
=
0
;
memcpy
(
&
pScanPhysiNode
->
tableName
,
&
pScanLogicNode
->
tableName
,
sizeof
(
SName
));
}
pScanPhysiNode
->
uid
=
pScanLogicNode
->
pMeta
->
uid
;
if
(
TSDB_CODE_SUCCESS
==
code
)
{
pScanPhysiNode
->
tableType
=
pScanLogicNode
->
pMeta
->
tableType
;
*
pPhyNode
=
(
SPhysiNode
*
)
pScanPhysiNode
;
pScanPhysiNode
->
order
=
TSDB_ORDER_ASC
;
}
else
{
pScanPhysiNode
->
count
=
1
;
nodesDestroyNode
(
pScanPhysiNode
);
pScanPhysiNode
->
reverse
=
0
;
}
memcpy
(
&
pScanPhysiNode
->
tableName
,
&
pScanLogicNode
->
tableName
,
sizeof
(
SName
));
return
TSDB_CODE_SUCCESS
;
return
code
;
}
}
static
void
vgroupInfoToNodeAddr
(
const
SVgroupInfo
*
vg
,
SQueryNodeAddr
*
pNodeAddr
)
{
static
void
vgroupInfoToNodeAddr
(
const
SVgroupInfo
*
vg
,
SQueryNodeAddr
*
pNodeAddr
)
{
...
@@ -248,30 +273,36 @@ static void vgroupInfoToNodeAddr(const SVgroupInfo* vg, SQueryNodeAddr* pNodeAdd
...
@@ -248,30 +273,36 @@ static void vgroupInfoToNodeAddr(const SVgroupInfo* vg, SQueryNodeAddr* pNodeAdd
pNodeAddr
->
epSet
=
vg
->
epSet
;
pNodeAddr
->
epSet
=
vg
->
epSet
;
}
}
static
SPhysiNode
*
createTagScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SScanLogicNode
*
pScanLogic
Node
)
{
static
int32_t
createTagScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SScanLogicNode
*
pScanLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
STagScanPhysiNode
*
pTagScan
=
(
STagScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_TAG_SCAN
);
STagScanPhysiNode
*
pTagScan
=
(
STagScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_TAG_SCAN
);
CHECK_ALLOC
(
pTagScan
,
NULL
);
if
(
NULL
==
pTagScan
)
{
CHECK_CODE
(
initScanPhysiNode
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pTagScan
),
(
SPhysiNode
*
)
pTagScan
);
return
TSDB_CODE_OUT_OF_MEMORY
;
return
(
SPhysiNode
*
)
pTagScan
;
}
return
createScanPhysiNodeFinalize
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pTagScan
,
pPhyNode
);
}
}
static
SPhysiNode
*
createTableScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogic
Node
)
{
static
int32_t
createTableScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
STableScanPhysiNode
*
pTableScan
=
(
STableScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN
);
STableScanPhysiNode
*
pTableScan
=
(
STableScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN
);
CHECK_ALLOC
(
pTableScan
,
NULL
);
if
(
NULL
==
pTableScan
)
{
CHECK_CODE
(
initScanPhysiNode
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pTableScan
),
(
SPhysiNode
*
)
pTableScan
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pTableScan
->
scanFlag
=
pScanLogicNode
->
scanFlag
;
pTableScan
->
scanFlag
=
pScanLogicNode
->
scanFlag
;
pTableScan
->
scanRange
=
pScanLogicNode
->
scanRange
;
pTableScan
->
scanRange
=
pScanLogicNode
->
scanRange
;
vgroupInfoToNodeAddr
(
pScanLogicNode
->
pVgroupList
->
vgroups
,
&
pSubplan
->
execNode
);
vgroupInfoToNodeAddr
(
pScanLogicNode
->
pVgroupList
->
vgroups
,
&
pSubplan
->
execNode
);
taosArrayPush
(
pCxt
->
pExecNodeList
,
&
pSubplan
->
execNode
);
taosArrayPush
(
pCxt
->
pExecNodeList
,
&
pSubplan
->
execNode
);
pSubplan
->
execNodeStat
.
tableNum
=
pScanLogicNode
->
pVgroupList
->
vgroups
[
0
].
numOfTable
;
pSubplan
->
execNodeStat
.
tableNum
=
pScanLogicNode
->
pVgroupList
->
vgroups
[
0
].
numOfTable
;
tNameGetFullDbName
(
&
pScanLogicNode
->
tableName
,
pSubplan
->
dbFName
);
tNameGetFullDbName
(
&
pScanLogicNode
->
tableName
,
pSubplan
->
dbFName
);
return
(
SPhysiNode
*
)
pTableScan
;
return
createScanPhysiNodeFinalize
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pTableScan
,
pPhyNode
);
}
}
static
SPhysiNode
*
createSystemTableScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogic
Node
)
{
static
int32_t
createSystemTableScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
SSystemTableScanPhysiNode
*
pScan
=
(
SSystemTableScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_SYSTABLE_SCAN
);
SSystemTableScanPhysiNode
*
pScan
=
(
SSystemTableScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_SYSTABLE_SCAN
);
CHECK_ALLOC
(
pScan
,
NULL
);
if
(
NULL
==
pScan
)
{
CHECK_CODE
(
initScanPhysiNode
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pScan
),
(
SPhysiNode
*
)
pScan
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
if
(
0
==
strcmp
(
pScanLogicNode
->
tableName
.
tname
,
TSDB_INS_TABLE_USER_TABLES
))
{
if
(
0
==
strcmp
(
pScanLogicNode
->
tableName
.
tname
,
TSDB_INS_TABLE_USER_TABLES
))
{
vgroupInfoToNodeAddr
(
pScanLogicNode
->
pVgroupList
->
vgroups
,
&
pSubplan
->
execNode
);
vgroupInfoToNodeAddr
(
pScanLogicNode
->
pVgroupList
->
vgroups
,
&
pSubplan
->
execNode
);
taosArrayPush
(
pCxt
->
pExecNodeList
,
&
pSubplan
->
execNode
);
taosArrayPush
(
pCxt
->
pExecNodeList
,
&
pSubplan
->
execNode
);
...
@@ -284,88 +315,104 @@ static SPhysiNode* createSystemTableScanPhysiNode(SPhysiPlanContext* pCxt, SSubp
...
@@ -284,88 +315,104 @@ static SPhysiNode* createSystemTableScanPhysiNode(SPhysiPlanContext* pCxt, SSubp
}
}
pScan
->
mgmtEpSet
=
pCxt
->
pPlanCxt
->
mgmtEpSet
;
pScan
->
mgmtEpSet
=
pCxt
->
pPlanCxt
->
mgmtEpSet
;
tNameGetFullDbName
(
&
pScanLogicNode
->
tableName
,
pSubplan
->
dbFName
);
tNameGetFullDbName
(
&
pScanLogicNode
->
tableName
,
pSubplan
->
dbFName
);
return
(
SPhysiNode
*
)
pScan
;
return
createScanPhysiNodeFinalize
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pScan
,
pPhyNode
);
}
}
static
SPhysiNode
*
createStreamScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogicNode
)
{
static
int32_t
createStreamScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogicNode
,
SPhysiNode
**
pPhyNode
)
{
SStreamScanPhysiNode
*
pTableScan
=
(
SStreamScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_STREAM_SCAN
);
SStreamScanPhysiNode
*
pScan
=
(
SStreamScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_STREAM_SCAN
);
CHECK_ALLOC
(
pTableScan
,
NULL
);
if
(
NULL
==
pScan
)
{
CHECK_CODE
(
initScanPhysiNode
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pTableScan
),
(
SPhysiNode
*
)
pTableScan
);
return
TSDB_CODE_OUT_OF_MEMORY
;
return
(
SPhysiNode
*
)
pTableScan
;
}
return
createScanPhysiNodeFinalize
(
pCxt
,
pScanLogicNode
,
(
SScanPhysiNode
*
)
pScan
,
pPhyNode
);
}
}
static
SPhysiNode
*
createScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogic
Node
)
{
static
int32_t
createScanPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SScanLogicNode
*
pScanLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
switch
(
pScanLogicNode
->
scanType
)
{
switch
(
pScanLogicNode
->
scanType
)
{
case
SCAN_TYPE_TAG
:
case
SCAN_TYPE_TAG
:
return
createTagScanPhysiNode
(
pCxt
,
pScanLogicNode
);
return
createTagScanPhysiNode
(
pCxt
,
pScanLogicNode
,
pPhyNode
);
case
SCAN_TYPE_TABLE
:
case
SCAN_TYPE_TABLE
:
return
createTableScanPhysiNode
(
pCxt
,
pSubplan
,
pScanLogicNode
);
return
createTableScanPhysiNode
(
pCxt
,
pSubplan
,
pScanLogicNode
,
pPhyNode
);
case
SCAN_TYPE_SYSTEM_TABLE
:
case
SCAN_TYPE_SYSTEM_TABLE
:
return
createSystemTableScanPhysiNode
(
pCxt
,
pSubplan
,
pScanLogicNode
);
return
createSystemTableScanPhysiNode
(
pCxt
,
pSubplan
,
pScanLogicNode
,
pPhyNode
);
case
SCAN_TYPE_STREAM
:
case
SCAN_TYPE_STREAM
:
return
createStreamScanPhysiNode
(
pCxt
,
pSubplan
,
pScanLogicNode
);
return
createStreamScanPhysiNode
(
pCxt
,
pSubplan
,
pScanLogicNode
,
pPhyNode
);
default:
default:
break
;
break
;
}
}
return
NULL
;
return
TSDB_CODE_FAILED
;
}
}
static
SNodeList
*
createJoinOutputCols
(
SPhysiPlanContext
*
pCxt
,
SDataBlockDescNode
*
pLeftDesc
,
SDataBlockDescNode
*
pRightDesc
)
{
static
int32_t
createColFromDataBlockDesc
(
SDataBlockDescNode
*
pDesc
,
SNodeList
*
pCols
)
{
SNodeList
*
pCols
=
nodesMakeList
();
CHECK_ALLOC
(
pCols
,
NULL
);
SNode
*
pNode
;
SNode
*
pNode
;
FOREACH
(
pNode
,
p
Left
Desc
->
pSlots
)
{
FOREACH
(
pNode
,
pDesc
->
pSlots
)
{
SSlotDescNode
*
pSlot
=
(
SSlotDescNode
*
)
pNode
;
SSlotDescNode
*
pSlot
=
(
SSlotDescNode
*
)
pNode
;
SColumnNode
*
pCol
=
(
SColumnNode
*
)
nodesMakeNode
(
QUERY_NODE_COLUMN
);
SColumnNode
*
pCol
=
(
SColumnNode
*
)
nodesMakeNode
(
QUERY_NODE_COLUMN
);
if
(
NULL
==
pCol
)
{
if
(
NULL
==
pCol
)
{
goto
error
;
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
pCol
->
node
.
resType
=
pSlot
->
dataType
;
pCol
->
node
.
resType
=
pSlot
->
dataType
;
pCol
->
dataBlockId
=
p
Left
Desc
->
dataBlockId
;
pCol
->
dataBlockId
=
pDesc
->
dataBlockId
;
pCol
->
slotId
=
pSlot
->
slotId
;
pCol
->
slotId
=
pSlot
->
slotId
;
pCol
->
colId
=
-
1
;
pCol
->
colId
=
-
1
;
if
(
TSDB_CODE_SUCCESS
!=
nodesListAppend
(
pCols
,
(
SNode
*
)
pCol
))
{
int32_t
code
=
nodesListStrictAppend
(
pCols
,
pCol
);
goto
error
;
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
return
code
;
}
}
}
}
FOREACH
(
pNode
,
pRightDesc
->
pSlots
)
{
return
TSDB_CODE_SUCCESS
;
SSlotDescNode
*
pSlot
=
(
SSlotDescNode
*
)
pNode
;
}
SColumnNode
*
pCol
=
(
SColumnNode
*
)
nodesMakeNode
(
QUERY_NODE_COLUMN
);
if
(
NULL
==
pCol
)
{
static
int32_t
createJoinOutputCols
(
SPhysiPlanContext
*
pCxt
,
SDataBlockDescNode
*
pLeftDesc
,
SDataBlockDescNode
*
pRightDesc
,
SNodeList
**
pList
)
{
goto
error
;
SNodeList
*
pCols
=
nodesMakeList
();
}
if
(
NULL
==
pCols
)
{
pCol
->
node
.
resType
=
pSlot
->
dataType
;
return
TSDB_CODE_OUT_OF_MEMORY
;
pCol
->
dataBlockId
=
pRightDesc
->
dataBlockId
;
}
pCol
->
slotId
=
pSlot
->
slotId
;
pCol
->
colId
=
-
1
;
int32_t
code
=
createColFromDataBlockDesc
(
pLeftDesc
,
pCols
);
if
(
TSDB_CODE_SUCCESS
!=
nodesListAppend
(
pCols
,
(
SNode
*
)
pCol
))
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
goto
error
;
code
=
createColFromDataBlockDesc
(
pRightDesc
,
pCols
);
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pList
=
pCols
;
}
else
{
nodesDestroyList
(
pCols
);
}
}
return
pCols
;
error:
return
code
;
nodesDestroyList
(
pCols
);
return
NULL
;
}
}
static
SPhysiNode
*
createJoinPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SJoinLogicNode
*
pJoinLogic
Node
)
{
static
int32_t
createJoinPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SJoinLogicNode
*
pJoinLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
SJoinPhysiNode
*
pJoin
=
(
SJoinPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_JOIN
);
SJoinPhysiNode
*
pJoin
=
(
SJoinPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_JOIN
);
CHECK_ALLOC
(
pJoin
,
NULL
);
if
(
NULL
==
pJoin
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
SDataBlockDescNode
*
pLeftDesc
=
((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
;
SDataBlockDescNode
*
pLeftDesc
=
((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
;
SDataBlockDescNode
*
pRightDesc
=
((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
1
))
->
pOutputDataBlockDesc
;
SDataBlockDescNode
*
pRightDesc
=
((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
1
))
->
pOutputDataBlockDesc
;
pJoin
->
pOnConditions
=
setNodeSlotId
(
pCxt
,
pLeftDesc
->
dataBlockId
,
pRightDesc
->
dataBlockId
,
pJoinLogicNode
->
pOnConditions
);
CHECK_ALLOC
(
pJoin
->
pOnConditions
,
(
SPhysiNode
*
)
pJoin
);
pJoin
->
pTargets
=
createJoinOutputCols
(
pCxt
,
pLeftDesc
,
pRightDesc
);
CHECK_ALLOC
(
pJoin
->
pTargets
,
(
SPhysiNode
*
)
pJoin
);
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pJoin
->
pTargets
,
pJoin
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pJoin
);
CHECK_CODE
(
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pJoinLogicNode
,
(
SPhysiNode
*
)
pJoin
),
(
SPhysiNode
*
)
pJoin
);
int32_t
code
=
setNodeSlotId
(
pCxt
,
pLeftDesc
->
dataBlockId
,
pRightDesc
->
dataBlockId
,
pJoinLogicNode
->
pOnConditions
,
&
pJoin
->
pOnConditions
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
createJoinOutputCols
(
pCxt
,
pLeftDesc
,
pRightDesc
,
&
pJoin
->
pTargets
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
addDataBlockDesc
(
pCxt
,
pJoin
->
pTargets
,
pJoin
->
node
.
pOutputDataBlockDesc
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pJoinLogicNode
,
(
SPhysiNode
*
)
pJoin
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setSlotOutput
(
pCxt
,
pJoinLogicNode
->
node
.
pTargets
,
pJoin
->
node
.
pOutputDataBlockDesc
);
}
CHECK_CODE
(
setSlotOutput
(
pCxt
,
pJoinLogicNode
->
node
.
pTargets
,
pJoin
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pJoin
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pPhyNode
=
(
SPhysiNode
*
)
pJoin
;
}
else
{
nodesDestroyNode
(
pJoin
);
}
return
(
SPhysiNode
*
)
pJoin
;
return
code
;
}
}
typedef
struct
SRewritePrecalcExprsCxt
{
typedef
struct
SRewritePrecalcExprsCxt
{
...
@@ -451,76 +498,169 @@ static int32_t rewritePrecalcExprs(SPhysiPlanContext* pCxt, SNodeList* pList, SN
...
@@ -451,76 +498,169 @@ static int32_t rewritePrecalcExprs(SPhysiPlanContext* pCxt, SNodeList* pList, SN
return
cxt
.
errCode
;
return
cxt
.
errCode
;
}
}
static
SPhysiNode
*
createAggPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SAggLogicNode
*
pAggLogic
Node
)
{
static
int32_t
createAggPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SAggLogicNode
*
pAggLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
SAggPhysiNode
*
pAgg
=
(
SAggPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_AGG
);
SAggPhysiNode
*
pAgg
=
(
SAggPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_AGG
);
CHECK_ALLOC
(
pAgg
,
NULL
);
if
(
NULL
==
pAgg
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
SNodeList
*
pPrecalcExprs
=
NULL
;
SNodeList
*
pPrecalcExprs
=
NULL
;
SNodeList
*
pGroupKeys
=
NULL
;
SNodeList
*
pGroupKeys
=
NULL
;
SNodeList
*
pAggFuncs
=
NULL
;
SNodeList
*
pAggFuncs
=
NULL
;
CHECK_CODE
(
rewritePrecalcExprs
(
pCxt
,
pAggLogicNode
->
pGroupKeys
,
&
pPrecalcExprs
,
&
pGroupKeys
),
(
SPhysiNode
*
)
pAgg
);
int32_t
code
=
rewritePrecalcExprs
(
pCxt
,
pAggLogicNode
->
pGroupKeys
,
&
pPrecalcExprs
,
&
pGroupKeys
);
CHECK_CODE
(
rewritePrecalcExprs
(
pCxt
,
pAggLogicNode
->
pAggFuncs
,
&
pPrecalcExprs
,
&
pAggFuncs
),
(
SPhysiNode
*
)
pAgg
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
rewritePrecalcExprs
(
pCxt
,
pAggLogicNode
->
pAggFuncs
,
&
pPrecalcExprs
,
&
pAggFuncs
);
}
SDataBlockDescNode
*
pChildTupe
=
(((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
);
SDataBlockDescNode
*
pChildTupe
=
(((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
);
// push down expression to pOutputDataBlockDesc of child node
// push down expression to pOutputDataBlockDesc of child node
if
(
NULL
!=
pPrecalcExprs
)
{
if
(
TSDB_CODE_SUCCESS
==
code
&&
NULL
!=
pPrecalcExprs
)
{
pAgg
->
pExprs
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pPrecalcExprs
);
code
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pPrecalcExprs
,
&
pAgg
->
pExprs
);
CHECK_ALLOC
(
pAgg
->
pExprs
,
(
SPhysiNode
*
)
pAgg
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pAgg
->
pExprs
,
pChildTupe
),
(
SPhysiNode
*
)
pAgg
);
code
=
addDataBlockDesc
(
pCxt
,
pAgg
->
pExprs
,
pChildTupe
);
}
}
}
if
(
NULL
!=
pGroupKeys
)
{
if
(
TSDB_CODE_SUCCESS
==
code
&&
NULL
!=
pGroupKeys
)
{
pAgg
->
pGroupKeys
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pGroupKeys
);
code
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pGroupKeys
,
&
pAgg
->
pGroupKeys
);
CHECK_ALLOC
(
pAgg
->
pGroupKeys
,
(
SPhysiNode
*
)
pAgg
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pAgg
->
pGroupKeys
,
pAgg
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pAgg
);
code
=
addDataBlockDesc
(
pCxt
,
pAgg
->
pGroupKeys
,
pAgg
->
node
.
pOutputDataBlockDesc
);
}
}
}
if
(
NULL
!=
pAggFuncs
)
{
if
(
TSDB_CODE_SUCCESS
==
code
&&
NULL
!=
pAggFuncs
)
{
pAgg
->
pAggFuncs
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pAggFuncs
);
code
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pAggFuncs
,
&
pAgg
->
pAggFuncs
);
CHECK_ALLOC
(
pAgg
->
pAggFuncs
,
(
SPhysiNode
*
)
pAgg
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pAgg
->
pAggFuncs
,
pAgg
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pAgg
);
code
=
addDataBlockDesc
(
pCxt
,
pAgg
->
pAggFuncs
,
pAgg
->
node
.
pOutputDataBlockDesc
);
}
}
}
CHECK_CODE
(
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pAggLogicNode
,
(
SPhysiNode
*
)
pAgg
),
(
SPhysiNode
*
)
pAgg
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pAggLogicNode
,
(
SPhysiNode
*
)
pAgg
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setSlotOutput
(
pCxt
,
pAggLogicNode
->
node
.
pTargets
,
pAgg
->
node
.
pOutputDataBlockDesc
);
}
CHECK_CODE
(
setSlotOutput
(
pCxt
,
pAggLogicNode
->
node
.
pTargets
,
pAgg
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pAgg
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pPhyNode
=
(
SPhysiNode
*
)
pAgg
;
}
else
{
nodesDestroyNode
(
pAgg
);
}
return
(
SPhysiNode
*
)
pAgg
;
return
code
;
}
}
static
SPhysiNode
*
createProjectPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SProjectLogicNode
*
pProjectLogic
Node
)
{
static
int32_t
createProjectPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SProjectLogicNode
*
pProjectLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
SProjectPhysiNode
*
pProject
=
(
SProjectPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_PROJECT
);
SProjectPhysiNode
*
pProject
=
(
SProjectPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_PROJECT
);
CHECK_ALLOC
(
pProject
,
NULL
);
if
(
NULL
==
pProject
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pProject
->
pProjections
=
setListSlotId
(
pCxt
,
((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
->
dataBlockId
,
-
1
,
pProjectLogicNode
->
pProjections
);
int32_t
code
=
setListSlotId
(
pCxt
,
((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
->
dataBlockId
,
-
1
,
pProjectLogicNode
->
pProjections
,
&
pProject
->
pProjections
);
CHECK_ALLOC
(
pProject
->
pProjections
,
(
SPhysiNode
*
)
pProject
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pProject
->
pProjections
,
pProject
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pProject
);
code
=
addDataBlockDesc
(
pCxt
,
pProject
->
pProjections
,
pProject
->
node
.
pOutputDataBlockDesc
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pProjectLogicNode
,
(
SPhysiNode
*
)
pProject
);
}
CHECK_CODE
(
setConditionsSlotId
(
pCxt
,
(
const
SLogicNode
*
)
pProjectLogicNode
,
(
SPhysiNode
*
)
pProject
),
(
SPhysiNode
*
)
pProject
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pPhyNode
=
(
SPhysiNode
*
)
pProject
;
}
else
{
nodesDestroyNode
(
pProject
);
}
return
(
SPhysiNode
*
)
pProject
;
return
code
;
}
}
static
SPhysiNode
*
createExchangePhysiNode
(
SPhysiPlanContext
*
pCxt
,
SExchangeLogicNode
*
pExchangeLogicNode
)
{
static
int32_t
doCreateExchangePhysiNode
(
SPhysiPlanContext
*
pCxt
,
SExchangeLogicNode
*
pExchangeLogicNode
,
SPhysiNode
**
pPhyNode
)
{
if
(
pCxt
->
pPlanCxt
->
streamQuery
)
{
SExchangePhysiNode
*
pExchange
=
(
SExchangePhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_EXCHANGE
);
SStreamScanPhysiNode
*
pScan
=
(
SStreamScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_STREAM_SCAN
);
if
(
NULL
==
pExchange
)
{
CHECK_ALLOC
(
pScan
,
NULL
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pExchange
->
srcGroupId
=
pExchangeLogicNode
->
srcGroupId
;
int32_t
code
=
addDataBlockDesc
(
pCxt
,
pExchangeLogicNode
->
node
.
pTargets
,
pExchange
->
node
.
pOutputDataBlockDesc
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pPhyNode
=
(
SPhysiNode
*
)
pExchange
;
}
else
{
nodesDestroyNode
(
pExchange
);
}
return
code
;
}
static
int32_t
createStreamScanPhysiNodeByExchange
(
SPhysiPlanContext
*
pCxt
,
SExchangeLogicNode
*
pExchangeLogicNode
,
SPhysiNode
**
pPhyNode
)
{
SStreamScanPhysiNode
*
pScan
=
(
SStreamScanPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_STREAM_SCAN
);
if
(
NULL
==
pScan
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
int32_t
code
=
addDataBlockDesc
(
pCxt
,
pExchangeLogicNode
->
node
.
pTargets
,
pScan
->
node
.
pOutputDataBlockDesc
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
pScan
->
pScanCols
=
nodesCloneList
(
pExchangeLogicNode
->
node
.
pTargets
);
pScan
->
pScanCols
=
nodesCloneList
(
pExchangeLogicNode
->
node
.
pTargets
);
CHECK_ALLOC
(
pScan
->
pScanCols
,
(
SPhysiNode
*
)
pScan
);
if
(
NULL
==
pScan
->
pScanCols
)
{
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pExchangeLogicNode
->
node
.
pTargets
,
pScan
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pScan
);
code
=
TSDB_CODE_OUT_OF_MEMORY
;
return
(
SPhysiNode
*
)
pScan
;
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pPhyNode
=
(
SPhysiNode
*
)
pScan
;
}
else
{
nodesDestroyNode
(
pScan
);
}
return
code
;
}
static
int32_t
createExchangePhysiNode
(
SPhysiPlanContext
*
pCxt
,
SExchangeLogicNode
*
pExchangeLogicNode
,
SPhysiNode
**
pPhyNode
)
{
if
(
pCxt
->
pPlanCxt
->
streamQuery
)
{
return
createStreamScanPhysiNodeByExchange
(
pCxt
,
pExchangeLogicNode
,
pPhyNode
);
}
else
{
}
else
{
SExchangePhysiNode
*
pExchange
=
(
SExchangePhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_EXCHANGE
);
return
doCreateExchangePhysiNode
(
pCxt
,
pExchangeLogicNode
,
pPhyNode
);
CHECK_ALLOC
(
pExchange
,
NULL
);
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pExchangeLogicNode
->
node
.
pTargets
,
pExchange
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pExchange
);
pExchange
->
srcGroupId
=
pExchangeLogicNode
->
srcGroupId
;
return
(
SPhysiNode
*
)
pExchange
;
}
}
}
}
static
SPhysiNode
*
createIntervalPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SWindowLogicNode
*
pWindowLogicNode
)
{
static
int32_t
createWindowPhysiNodeFinalize
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SWinodwPhysiNode
*
pWindow
,
SWindowLogicNode
*
pWindowLogicNode
,
SPhysiNode
**
pPhyNode
)
{
SNodeList
*
pPrecalcExprs
=
NULL
;
SNodeList
*
pFuncs
=
NULL
;
int32_t
code
=
rewritePrecalcExprs
(
pCxt
,
pWindowLogicNode
->
pFuncs
,
&
pPrecalcExprs
,
&
pFuncs
);
SDataBlockDescNode
*
pChildTupe
=
(((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
);
// push down expression to pOutputDataBlockDesc of child node
if
(
TSDB_CODE_SUCCESS
==
code
&&
NULL
!=
pPrecalcExprs
)
{
code
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pPrecalcExprs
,
&
pWindow
->
pExprs
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
addDataBlockDesc
(
pCxt
,
pWindow
->
pExprs
,
pChildTupe
);
}
}
if
(
TSDB_CODE_SUCCESS
==
code
&&
NULL
!=
pFuncs
)
{
code
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pFuncs
,
&
pWindow
->
pFuncs
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
addDataBlockDesc
(
pCxt
,
pWindow
->
pFuncs
,
pWindow
->
node
.
pOutputDataBlockDesc
);
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
setSlotOutput
(
pCxt
,
pWindowLogicNode
->
node
.
pTargets
,
pWindow
->
node
.
pOutputDataBlockDesc
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pPhyNode
=
(
SPhysiNode
*
)
pWindow
;
}
else
{
nodesDestroyNode
(
pWindow
);
}
return
code
;
}
static
int32_t
createIntervalPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SWindowLogicNode
*
pWindowLogicNode
,
SPhysiNode
**
pPhyNode
)
{
SIntervalPhysiNode
*
pInterval
=
(
SIntervalPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
);
SIntervalPhysiNode
*
pInterval
=
(
SIntervalPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_INTERVAL
);
CHECK_ALLOC
(
pInterval
,
NULL
);
if
(
NULL
==
pInterval
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pInterval
->
interval
=
pWindowLogicNode
->
interval
;
pInterval
->
interval
=
pWindowLogicNode
->
interval
;
pInterval
->
offset
=
pWindowLogicNode
->
offset
;
pInterval
->
offset
=
pWindowLogicNode
->
offset
;
...
@@ -529,163 +669,178 @@ static SPhysiNode* createIntervalPhysiNode(SPhysiPlanContext* pCxt, SNodeList* p
...
@@ -529,163 +669,178 @@ static SPhysiNode* createIntervalPhysiNode(SPhysiPlanContext* pCxt, SNodeList* p
pInterval
->
slidingUnit
=
pWindowLogicNode
->
slidingUnit
;
pInterval
->
slidingUnit
=
pWindowLogicNode
->
slidingUnit
;
pInterval
->
pFill
=
nodesCloneNode
(
pWindowLogicNode
->
pFill
);
pInterval
->
pFill
=
nodesCloneNode
(
pWindowLogicNode
->
pFill
);
if
(
NULL
!=
pWindowLogicNode
->
pFill
&&
NULL
==
pInterval
->
pFill
)
{
SNodeList
*
pPrecalcExprs
=
NULL
;
nodesDestroyNode
(
pInterval
);
SNodeList
*
pFuncs
=
NULL
;
return
TSDB_CODE_OUT_OF_MEMORY
;
CHECK_CODE
(
rewritePrecalcExprs
(
pCxt
,
pWindowLogicNode
->
pFuncs
,
&
pPrecalcExprs
,
&
pFuncs
),
(
SPhysiNode
*
)
pInterval
);
SDataBlockDescNode
*
pChildTupe
=
(((
SPhysiNode
*
)
nodesListGetNode
(
pChildren
,
0
))
->
pOutputDataBlockDesc
);
// push down expression to pOutputDataBlockDesc of child node
if
(
NULL
!=
pPrecalcExprs
)
{
pInterval
->
pExprs
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pPrecalcExprs
);
CHECK_ALLOC
(
pInterval
->
pExprs
,
(
SPhysiNode
*
)
pInterval
);
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pInterval
->
pExprs
,
pChildTupe
),
(
SPhysiNode
*
)
pInterval
);
}
}
if
(
NULL
!=
pFuncs
)
{
return
createWindowPhysiNodeFinalize
(
pCxt
,
pChildren
,
&
pInterval
->
window
,
pWindowLogicNode
,
pPhyNode
);
pInterval
->
pFuncs
=
setListSlotId
(
pCxt
,
pChildTupe
->
dataBlockId
,
-
1
,
pFuncs
);
}
CHECK_ALLOC
(
pInterval
->
pFuncs
,
(
SPhysiNode
*
)
pInterval
);
CHECK_CODE
(
addDataBlockDesc
(
pCxt
,
pInterval
->
pFuncs
,
pInterval
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pInterval
);
static
int32_t
createSessionWindowPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SWindowLogicNode
*
pWindowLogicNode
,
SPhysiNode
**
pPhyNode
)
{
SSessionWinodwPhysiNode
*
pSession
=
(
SSessionWinodwPhysiNode
*
)
makePhysiNode
(
pCxt
,
QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW
);
if
(
NULL
==
pSession
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
CHECK_CODE
(
setSlotOutput
(
pCxt
,
pWindowLogicNode
->
node
.
pTargets
,
pInterval
->
node
.
pOutputDataBlockDesc
),
(
SPhysiNode
*
)
pInterval
)
;
pSession
->
gap
=
pWindowLogicNode
->
sessionGap
;
return
(
SPhysiNode
*
)
pInterval
;
return
createWindowPhysiNodeFinalize
(
pCxt
,
pChildren
,
&
pSession
->
window
,
pWindowLogicNode
,
pPhyNode
)
;
}
}
static
SPhysiNode
*
createWindowPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SWindowLogicNode
*
pWindowLogic
Node
)
{
static
int32_t
createWindowPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pChildren
,
SWindowLogicNode
*
pWindowLogicNode
,
SPhysiNode
**
pPhy
Node
)
{
switch
(
pWindowLogicNode
->
winType
)
{
switch
(
pWindowLogicNode
->
winType
)
{
case
WINDOW_TYPE_INTERVAL
:
case
WINDOW_TYPE_INTERVAL
:
return
createIntervalPhysiNode
(
pCxt
,
pChildren
,
pWindowLogicNode
);
return
createIntervalPhysiNode
(
pCxt
,
pChildren
,
pWindowLogicNode
,
pPhyNode
);
case
WINDOW_TYPE_SESSION
:
case
WINDOW_TYPE_SESSION
:
return
createSessionWindowPhysiNode
(
pCxt
,
pChildren
,
pWindowLogicNode
,
pPhyNode
);
case
WINDOW_TYPE_STATE
:
case
WINDOW_TYPE_STATE
:
break
;
break
;
default:
default:
break
;
break
;
}
}
return
NULL
;
return
TSDB_CODE_FAILED
;
}
}
static
SPhysiNode
*
createPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SSubplan
*
pSubplan
,
SLogicNode
*
pLogicPlan
)
{
static
int32_t
doCreatePhysiNode
(
SPhysiPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
,
SSubplan
*
pSubplan
,
SNodeList
*
pChildren
,
SPhysiNode
**
pPhyNode
)
{
SNodeList
*
pChildren
=
nodesMakeList
();
switch
(
nodeType
(
pLogicNode
))
{
CHECK_ALLOC
(
pChildren
,
NULL
);
SNode
*
pLogicChild
;
FOREACH
(
pLogicChild
,
pLogicPlan
->
pChildren
)
{
if
(
TSDB_CODE_SUCCESS
!=
nodesListStrictAppend
(
pChildren
,
createPhysiNode
(
pCxt
,
pSubplan
,
(
SLogicNode
*
)
pLogicChild
)))
{
pCxt
->
errCode
=
TSDB_CODE_OUT_OF_MEMORY
;
nodesDestroyList
(
pChildren
);
return
NULL
;
}
}
SPhysiNode
*
pPhyNode
=
NULL
;
switch
(
nodeType
(
pLogicPlan
))
{
case
QUERY_NODE_LOGIC_PLAN_SCAN
:
case
QUERY_NODE_LOGIC_PLAN_SCAN
:
pPhyNode
=
createScanPhysiNode
(
pCxt
,
pSubplan
,
(
SScanLogicNode
*
)
pLogicPlan
);
return
createScanPhysiNode
(
pCxt
,
pSubplan
,
(
SScanLogicNode
*
)
pLogicNode
,
pPhyNode
);
break
;
case
QUERY_NODE_LOGIC_PLAN_JOIN
:
case
QUERY_NODE_LOGIC_PLAN_JOIN
:
pPhyNode
=
createJoinPhysiNode
(
pCxt
,
pChildren
,
(
SJoinLogicNode
*
)
pLogicPlan
);
return
createJoinPhysiNode
(
pCxt
,
pChildren
,
(
SJoinLogicNode
*
)
pLogicNode
,
pPhyNode
);
break
;
case
QUERY_NODE_LOGIC_PLAN_AGG
:
case
QUERY_NODE_LOGIC_PLAN_AGG
:
pPhyNode
=
createAggPhysiNode
(
pCxt
,
pChildren
,
(
SAggLogicNode
*
)
pLogicPlan
);
return
createAggPhysiNode
(
pCxt
,
pChildren
,
(
SAggLogicNode
*
)
pLogicNode
,
pPhyNode
);
break
;
case
QUERY_NODE_LOGIC_PLAN_PROJECT
:
case
QUERY_NODE_LOGIC_PLAN_PROJECT
:
pPhyNode
=
createProjectPhysiNode
(
pCxt
,
pChildren
,
(
SProjectLogicNode
*
)
pLogicPlan
);
return
createProjectPhysiNode
(
pCxt
,
pChildren
,
(
SProjectLogicNode
*
)
pLogicNode
,
pPhyNode
);
break
;
case
QUERY_NODE_LOGIC_PLAN_EXCHANGE
:
case
QUERY_NODE_LOGIC_PLAN_EXCHANGE
:
pPhyNode
=
createExchangePhysiNode
(
pCxt
,
(
SExchangeLogicNode
*
)
pLogicPlan
);
return
createExchangePhysiNode
(
pCxt
,
(
SExchangeLogicNode
*
)
pLogicNode
,
pPhyNode
);
break
;
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
case
QUERY_NODE_LOGIC_PLAN_WINDOW
:
pPhyNode
=
createWindowPhysiNode
(
pCxt
,
pChildren
,
(
SWindowLogicNode
*
)
pLogicPlan
);
return
createWindowPhysiNode
(
pCxt
,
pChildren
,
(
SWindowLogicNode
*
)
pLogicNode
,
pPhyNode
);
break
;
default:
default:
break
;
break
;
}
}
if
(
TSDB_CODE_SUCCESS
!=
pCxt
->
errCode
)
{
nodesDestroyNode
(
pPhyNode
);
return
TSDB_CODE_FAILED
;
return
NULL
;
}
static
int32_t
createPhysiNode
(
SPhysiPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
,
SSubplan
*
pSubplan
,
SPhysiNode
**
pPhyNode
)
{
SNodeList
*
pChildren
=
nodesMakeList
();
if
(
NULL
==
pChildren
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
int32_t
code
=
TSDB_CODE_SUCCESS
;
SNode
*
pLogicChild
;
FOREACH
(
pLogicChild
,
pLogicNode
->
pChildren
)
{
SPhysiNode
*
pChild
=
NULL
;
code
=
createPhysiNode
(
pCxt
,
(
SLogicNode
*
)
pLogicChild
,
pSubplan
,
&
pChild
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodesListStrictAppend
(
pChildren
,
pChild
);
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
doCreatePhysiNode
(
pCxt
,
pLogicNode
,
pSubplan
,
pChildren
,
pPhyNode
);
}
}
pPhyNode
->
pChildren
=
pChildren
;
if
(
TSDB_CODE_SUCCESS
==
code
)
{
SNode
*
pChild
;
(
*
pPhyNode
)
->
pChildren
=
pChildren
;
FOREACH
(
pChild
,
pPhyNode
->
pChildren
)
{
SNode
*
pChild
;
((
SPhysiNode
*
)
pChild
)
->
pParent
=
pPhyNode
;
FOREACH
(
pChild
,
(
*
pPhyNode
)
->
pChildren
)
{
((
SPhysiNode
*
)
pChild
)
->
pParent
=
(
*
pPhyNode
);
}
}
else
{
nodesDestroyList
(
pChildren
);
}
}
return
pPhyN
ode
;
return
c
ode
;
}
}
static
SDataSinkNode
*
createDataInserter
(
SPhysiPlanContext
*
pCxt
,
SVgDataBlocks
*
pBlocks
)
{
static
int32_t
createDataInserter
(
SPhysiPlanContext
*
pCxt
,
SVgDataBlocks
*
pBlocks
,
SDataSinkNode
**
pSink
)
{
SDataInserterNode
*
pInserter
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_PLAN_INSERT
);
SDataInserterNode
*
pInserter
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_PLAN_INSERT
);
CHECK_ALLOC
(
pInserter
,
NULL
);
if
(
NULL
==
pInserter
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pInserter
->
numOfTables
=
pBlocks
->
numOfTables
;
pInserter
->
numOfTables
=
pBlocks
->
numOfTables
;
pInserter
->
size
=
pBlocks
->
size
;
pInserter
->
size
=
pBlocks
->
size
;
TSWAP
(
pInserter
->
pData
,
pBlocks
->
pData
,
char
*
);
TSWAP
(
pInserter
->
pData
,
pBlocks
->
pData
,
char
*
);
return
(
SDataSinkNode
*
)
pInserter
;
*
pSink
=
(
SDataSinkNode
*
)
pInserter
;
return
TSDB_CODE_SUCCESS
;
}
}
static
SDataSinkNode
*
createDataDispatcher
(
SPhysiPlanContext
*
pCxt
,
const
SPhysiNode
*
pRoot
)
{
static
int32_t
createDataDispatcher
(
SPhysiPlanContext
*
pCxt
,
const
SPhysiNode
*
pRoot
,
SDataSinkNode
**
pSink
)
{
SDataDispatcherNode
*
pDispatcher
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
);
SDataDispatcherNode
*
pDispatcher
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_PLAN_DISPATCH
);
CHECK_ALLOC
(
pDispatcher
,
NULL
);
if
(
NULL
==
pDispatcher
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pDispatcher
->
sink
.
pInputDataBlockDesc
=
nodesCloneNode
(
pRoot
->
pOutputDataBlockDesc
);
pDispatcher
->
sink
.
pInputDataBlockDesc
=
nodesCloneNode
(
pRoot
->
pOutputDataBlockDesc
);
CHECK_ALLOC
(
pDispatcher
->
sink
.
pInputDataBlockDesc
,
(
SDataSinkNode
*
)
pDispatcher
);
if
(
NULL
==
pDispatcher
->
sink
.
pInputDataBlockDesc
)
{
return
(
SDataSinkNode
*
)
pDispatcher
;
nodesDestroyNode
(
pDispatcher
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
*
pSink
=
(
SDataSinkNode
*
)
pDispatcher
;
return
TSDB_CODE_SUCCESS
;
}
}
static
SSubplan
*
makeSubplan
(
SPhysiPlanContext
*
pCxt
,
S
SubLogicP
lan
*
pLogicSubplan
)
{
static
SSubplan
*
makeSubplan
(
SPhysiPlanContext
*
pCxt
,
S
LogicSubp
lan
*
pLogicSubplan
)
{
SSubplan
*
pSubplan
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_SUBPLAN
);
SSubplan
*
pSubplan
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_SUBPLAN
);
CHECK_ALLOC
(
pSubplan
,
NULL
);
if
(
NULL
==
pSubplan
)
{
return
NULL
;
}
pSubplan
->
id
=
pLogicSubplan
->
id
;
pSubplan
->
id
=
pLogicSubplan
->
id
;
pSubplan
->
subplanType
=
pLogicSubplan
->
subplanType
;
pSubplan
->
subplanType
=
pLogicSubplan
->
subplanType
;
pSubplan
->
level
=
pLogicSubplan
->
level
;
pSubplan
->
level
=
pLogicSubplan
->
level
;
return
pSubplan
;
return
pSubplan
;
}
}
static
SSubplan
*
createPhysiSubplan
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pLogic
Subplan
)
{
static
int32_t
createPhysiSubplan
(
SPhysiPlanContext
*
pCxt
,
SLogicSubplan
*
pLogicSubplan
,
SSubplan
**
pPhysi
Subplan
)
{
SSubplan
*
pSubplan
=
makeSubplan
(
pCxt
,
pLogicSubplan
);
SSubplan
*
pSubplan
=
makeSubplan
(
pCxt
,
pLogicSubplan
);
CHECK_ALLOC
(
pSubplan
,
NULL
);
if
(
NULL
==
pSubplan
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
int32_t
code
=
TSDB_CODE_SUCCESS
;
if
(
SUBPLAN_TYPE_MODIFY
==
pLogicSubplan
->
subplanType
)
{
if
(
SUBPLAN_TYPE_MODIFY
==
pLogicSubplan
->
subplanType
)
{
SVnodeModifLogicNode
*
pModif
=
(
SVnodeModifLogicNode
*
)
pLogicSubplan
->
pNode
;
SVnodeModifLogicNode
*
pModif
=
(
SVnodeModifLogicNode
*
)
pLogicSubplan
->
pNode
;
pSubplan
->
pDataSink
=
createDataInserter
(
pCxt
,
pModif
->
pVgDataBlocks
);
pSubplan
->
msgType
=
pModif
->
msgType
;
pSubplan
->
msgType
=
pModif
->
msgType
;
pSubplan
->
execNode
.
epSet
=
pModif
->
pVgDataBlocks
->
vg
.
epSet
;
pSubplan
->
execNode
.
epSet
=
pModif
->
pVgDataBlocks
->
vg
.
epSet
;
taosArrayPush
(
pCxt
->
pExecNodeList
,
&
pSubplan
->
execNode
);
taosArrayPush
(
pCxt
->
pExecNodeList
,
&
pSubplan
->
execNode
);
code
=
createDataInserter
(
pCxt
,
pModif
->
pVgDataBlocks
,
&
pSubplan
->
pDataSink
);
}
else
{
}
else
{
pSubplan
->
pNode
=
createPhysiNode
(
pCxt
,
pSubplan
,
pLogicSubplan
->
pNode
);
if
(
!
pCxt
->
pPlanCxt
->
streamQuery
&&
!
pCxt
->
pPlanCxt
->
topicQuery
)
{
pSubplan
->
pDataSink
=
createDataDispatcher
(
pCxt
,
pSubplan
->
pNode
);
}
pSubplan
->
msgType
=
TDMT_VND_QUERY
;
pSubplan
->
msgType
=
TDMT_VND_QUERY
;
code
=
createPhysiNode
(
pCxt
,
pLogicSubplan
->
pNode
,
pSubplan
,
&
pSubplan
->
pNode
);
if
(
TSDB_CODE_SUCCESS
==
code
&&
!
pCxt
->
pPlanCxt
->
streamQuery
&&
!
pCxt
->
pPlanCxt
->
topicQuery
)
{
code
=
createDataDispatcher
(
pCxt
,
pSubplan
->
pNode
,
&
pSubplan
->
pDataSink
);
}
}
}
return
pSubplan
;
}
static
void
doSetLogicNodeParent
(
SLogicNode
*
pNode
,
SLogicNode
*
pParent
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
pNode
->
pParent
=
pParent
;
*
pPhysiSubplan
=
pSubplan
;
SNode
*
pChild
;
}
else
{
FOREACH
(
pChild
,
pNode
->
pChildren
)
{
nodesDestroyNode
(
pSubplan
);
doSetLogicNodeParent
((
SLogicNode
*
)
pChild
,
pNode
);
}
}
return
code
;
}
}
static
void
setLogicNodeParent
(
SLogicNode
*
pNode
)
{
static
SQueryPlan
*
makeQueryPhysiPlan
(
SPhysiPlanContext
*
pCxt
)
{
doSetLogicNodeParent
(
pNode
,
NULL
);
SQueryPlan
*
pPlan
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_PLAN
);
}
if
(
NULL
==
pPlan
)
{
return
NULL
;
static
int32_t
splitLogicPlan
(
SPhysiPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
,
SSubLogicPlan
**
pSubLogicPlan
)
{
}
*
pSubLogicPlan
=
(
SSubLogicPlan
*
)
nodesMakeNode
(
QUERY_NODE_LOGIC_SUBPLAN
);
pPlan
->
pSubplans
=
nodesMakeList
();
CHECK_ALLOC
(
*
pSubLogicPlan
,
TSDB_CODE_OUT_OF_MEMORY
);
if
(
NULL
==
pPlan
->
pSubplans
)
{
(
*
pSubLogicPlan
)
->
pNode
=
nodesCloneNode
(
pLogicNode
);
nodesDestroyNode
(
pPlan
);
if
(
QUERY_NODE_LOGIC_PLAN_VNODE_MODIF
==
nodeType
(
pLogicNode
))
{
return
NULL
;
(
*
pSubLogicPlan
)
->
subplanType
=
SUBPLAN_TYPE_MODIFY
;
TSWAP
(((
SVnodeModifLogicNode
*
)
pLogicNode
)
->
pDataBlocks
,
((
SVnodeModifLogicNode
*
)(
*
pSubLogicPlan
)
->
pNode
)
->
pDataBlocks
,
SArray
*
);
}
else
{
(
*
pSubLogicPlan
)
->
subplanType
=
SUBPLAN_TYPE_SCAN
;
}
}
(
*
pSubLogicPlan
)
->
id
.
queryId
=
pCxt
->
pPlanCxt
->
queryId
;
pPlan
->
queryId
=
pCxt
->
pPlanCxt
->
queryId
;
setLogicNodeParent
((
*
pSubLogicPlan
)
->
pNode
);
return
pPlan
;
return
applySplitRule
(
*
pSubLogicPlan
);
}
}
static
int32_t
pushSubplan
(
SPhysiPlanContext
*
pCxt
,
SNodeptr
pSubplan
,
int32_t
level
,
SNodeList
*
pSubplans
)
{
static
int32_t
pushSubplan
(
SPhysiPlanContext
*
pCxt
,
SNodeptr
pSubplan
,
int32_t
level
,
SNodeList
*
pSubplans
)
{
...
@@ -705,193 +860,65 @@ static int32_t pushSubplan(SPhysiPlanContext* pCxt, SNodeptr pSubplan, int32_t l
...
@@ -705,193 +860,65 @@ static int32_t pushSubplan(SPhysiPlanContext* pCxt, SNodeptr pSubplan, int32_t l
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
static
SSubLogicPlan
*
singleCloneSubLogicPlan
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pSrc
,
int32_t
level
)
{
static
int32_t
buildPhysiPlan
(
SPhysiPlanContext
*
pCxt
,
SLogicSubplan
*
pLogicSubplan
,
SSubplan
*
pParent
,
SQueryPlan
*
pQueryPlan
)
{
SSubLogicPlan
*
pDst
=
nodesMakeNode
(
QUERY_NODE_LOGIC_SUBPLAN
);
SSubplan
*
pSubplan
=
NULL
;
CHECK_ALLOC
(
pDst
,
NULL
);
int32_t
code
=
createPhysiSubplan
(
pCxt
,
pLogicSubplan
,
&
pSubplan
);
pDst
->
pNode
=
nodesCloneNode
(
pSrc
->
pNode
);
if
(
NULL
==
pDst
->
pNode
)
{
nodesDestroyNode
(
pDst
);
return
NULL
;
}
pDst
->
subplanType
=
pSrc
->
subplanType
;
pDst
->
level
=
level
;
pDst
->
id
.
queryId
=
pSrc
->
id
.
queryId
;
pDst
->
id
.
groupId
=
pSrc
->
id
.
groupId
;
pDst
->
id
.
subplanId
=
pCxt
->
subplanId
++
;
return
pDst
;
}
static
int32_t
scaleOutForModify
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pSubplan
,
int32_t
level
,
SNodeList
*
pGroup
)
{
SVnodeModifLogicNode
*
pNode
=
(
SVnodeModifLogicNode
*
)
pSubplan
->
pNode
;
size_t
numOfVgroups
=
taosArrayGetSize
(
pNode
->
pDataBlocks
);
for
(
int32_t
i
=
0
;
i
<
numOfVgroups
;
++
i
)
{
SSubLogicPlan
*
pNewSubplan
=
singleCloneSubLogicPlan
(
pCxt
,
pSubplan
,
level
);
CHECK_ALLOC
(
pNewSubplan
,
TSDB_CODE_OUT_OF_MEMORY
);
SVgDataBlocks
*
blocks
=
(
SVgDataBlocks
*
)
taosArrayGetP
(
pNode
->
pDataBlocks
,
i
);
((
SVnodeModifLogicNode
*
)
pNewSubplan
->
pNode
)
->
pVgDataBlocks
=
blocks
;
CHECK_CODE_EXT
(
nodesListAppend
(
pGroup
,
pNewSubplan
));
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
scaleOutForMerge
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pSubplan
,
int32_t
level
,
SNodeList
*
pGroup
)
{
return
nodesListStrictAppend
(
pGroup
,
singleCloneSubLogicPlan
(
pCxt
,
pSubplan
,
level
));
}
static
int32_t
doSetScanVgroup
(
SPhysiPlanContext
*
pCxt
,
SLogicNode
*
pNode
,
const
SVgroupInfo
*
pVgroup
,
bool
*
pFound
)
{
if
(
QUERY_NODE_LOGIC_PLAN_SCAN
==
nodeType
(
pNode
))
{
SScanLogicNode
*
pScan
=
(
SScanLogicNode
*
)
pNode
;
pScan
->
pVgroupList
=
calloc
(
1
,
sizeof
(
SVgroupsInfo
)
+
sizeof
(
SVgroupInfo
));
CHECK_ALLOC
(
pScan
->
pVgroupList
,
TSDB_CODE_OUT_OF_MEMORY
);
memcpy
(
pScan
->
pVgroupList
->
vgroups
,
pVgroup
,
sizeof
(
SVgroupInfo
));
*
pFound
=
true
;
return
TSDB_CODE_SUCCESS
;
}
SNode
*
pChild
=
NULL
;
FOREACH
(
pChild
,
pNode
->
pChildren
)
{
int32_t
code
=
doSetScanVgroup
(
pCxt
,
(
SLogicNode
*
)
pChild
,
pVgroup
,
pFound
);
if
(
TSDB_CODE_SUCCESS
!=
code
||
*
pFound
)
{
return
code
;
}
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
setScanVgroup
(
SPhysiPlanContext
*
pCxt
,
SLogicNode
*
pNode
,
const
SVgroupInfo
*
pVgroup
)
{
bool
found
=
false
;
return
doSetScanVgroup
(
pCxt
,
pNode
,
pVgroup
,
&
found
);
}
static
int32_t
scaleOutForScan
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pSubplan
,
int32_t
level
,
SNodeList
*
pGroup
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
pSubplan
->
pVgroupList
)
{
code
=
pushSubplan
(
pCxt
,
pSubplan
,
pLogicSubplan
->
level
,
pQueryPlan
->
pSubplans
);
for
(
int32_t
i
=
0
;
i
<
pSubplan
->
pVgroupList
->
numOfVgroups
;
++
i
)
{
++
(
pQueryPlan
->
numOfSubplans
);
SSubLogicPlan
*
pNewSubplan
=
singleCloneSubLogicPlan
(
pCxt
,
pSubplan
,
level
);
CHECK_ALLOC
(
pNewSubplan
,
TSDB_CODE_OUT_OF_MEMORY
);
CHECK_CODE_EXT
(
setScanVgroup
(
pCxt
,
pNewSubplan
->
pNode
,
pSubplan
->
pVgroupList
->
vgroups
+
i
));
CHECK_CODE_EXT
(
nodesListAppend
(
pGroup
,
pNewSubplan
));
}
return
TSDB_CODE_SUCCESS
;
}
else
{
return
scaleOutForMerge
(
pCxt
,
pSubplan
,
level
,
pGroup
);
}
}
}
static
int32_t
appendWithMakeList
(
SNodeList
**
pList
,
SNodeptr
pNode
)
{
if
(
TSDB_CODE_SUCCESS
==
code
&&
NULL
!=
pParent
)
{
if
(
NULL
==
*
pList
)
{
code
=
nodesListMakeAppend
(
&
pParent
->
pChildren
,
pSubplan
);
*
pList
=
nodesMakeList
();
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
NULL
==
*
pList
)
{
code
=
nodesListMakeAppend
(
&
pSubplan
->
pParents
,
pParent
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
}
}
return
nodesListAppend
(
*
pList
,
pNode
);
}
static
int32_t
pushHierarchicalPlan
(
SPhysiPlanContext
*
pCxt
,
SNodeList
*
pParentsGroup
,
SNodeList
*
pCurrentGroup
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
bool
topLevel
=
(
0
==
LIST_LENGTH
(
pParentsGroup
));
SNode
*
pChild
=
NULL
;
SNode
*
pChild
=
NULL
;
FOREACH
(
pChild
,
pLogicSubplan
->
pChildren
)
{
FOREACH
(
pChild
,
pCurrentGroup
)
{
code
=
buildPhysiPlan
(
pCxt
,
(
SLogicSubplan
*
)
pChild
,
pSubplan
,
pQueryPlan
);
if
(
topLevel
)
{
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
CHECK_CODE_EXT
(
nodesListAppend
(
pParentsGroup
,
pChild
));
break
;
}
else
{
SNode
*
pParent
=
NULL
;
FOREACH
(
pParent
,
pParentsGroup
)
{
CHECK_CODE_EXT
(
appendWithMakeList
(
&
(((
SSubLogicPlan
*
)
pParent
)
->
pChildren
),
pChild
));
CHECK_CODE_EXT
(
appendWithMakeList
(
&
(((
SSubLogicPlan
*
)
pChild
)
->
pParents
),
pParent
));
}
}
}
}
}
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
doScaleOut
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pSubplan
,
int32_t
*
pLevel
,
SNodeList
*
pParentsGroup
)
{
SNodeList
*
pCurrentGroup
=
nodesMakeList
();
CHECK_ALLOC
(
pCurrentGroup
,
TSDB_CODE_OUT_OF_MEMORY
);
int32_t
code
=
TSDB_CODE_SUCCESS
;
switch
(
pSubplan
->
subplanType
)
{
case
SUBPLAN_TYPE_MERGE
:
code
=
scaleOutForMerge
(
pCxt
,
pSubplan
,
*
pLevel
,
pCurrentGroup
);
break
;
case
SUBPLAN_TYPE_SCAN
:
code
=
scaleOutForScan
(
pCxt
,
pSubplan
,
*
pLevel
,
pCurrentGroup
);
break
;
case
SUBPLAN_TYPE_MODIFY
:
code
=
scaleOutForModify
(
pCxt
,
pSubplan
,
*
pLevel
,
pCurrentGroup
);
break
;
default:
break
;
}
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
return
code
;
nodesDestroyNode
(
pSubplan
)
;
}
}
CHECK_CODE_EXT
(
pushHierarchicalPlan
(
pCxt
,
pParentsGroup
,
pCurrentGroup
));
return
code
;
++
(
*
pLevel
);
SNode
*
pChild
;
FOREACH
(
pChild
,
pSubplan
->
pChildren
)
{
CHECK_CODE_EXT
(
doScaleOut
(
pCxt
,
(
SSubLogicPlan
*
)
pChild
,
pLevel
,
pCurrentGroup
));
}
return
TSDB_CODE_SUCCESS
;
}
}
static
SQueryLogicPlan
*
makeQueryLogicPlan
(
SPhysiPlanContext
*
pCxt
)
{
static
int32_t
doCreatePhysiPlan
(
SPhysiPlanContext
*
pCxt
,
SQueryLogicPlan
*
pLogicPlan
,
SQueryPlan
**
pPhysiPlan
)
{
SQueryLogicPlan
*
pLogicPlan
=
(
SQueryLogicPlan
*
)
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN
);
SQueryPlan
*
pPlan
=
makeQueryPhysiPlan
(
pCxt
);
CHECK_ALLOC
(
pLogicPlan
,
NULL
);
if
(
NULL
==
pPlan
)
{
pLogicPlan
->
pTopSubplans
=
nodesMakeList
();
return
TSDB_CODE_OUT_OF_MEMORY
;
if
(
NULL
==
pLogicPlan
->
pTopSubplans
)
{
nodesDestroyNode
(
pLogicPlan
);
return
NULL
;
}
}
return
pLogicPlan
;
}
static
int32_t
scaleOutLogicPlan
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pRootSubLogicPlan
,
SQueryLogicPlan
**
pLogicPlan
)
{
*
pLogicPlan
=
makeQueryLogicPlan
(
pCxt
);
CHECK_ALLOC
(
*
pLogicPlan
,
TSDB_CODE_OUT_OF_MEMORY
);
return
doScaleOut
(
pCxt
,
pRootSubLogicPlan
,
&
((
*
pLogicPlan
)
->
totalLevel
),
(
*
pLogicPlan
)
->
pTopSubplans
);
}
static
SQueryPlan
*
makeQueryPhysiPlan
(
SPhysiPlanContext
*
pCxt
)
{
int32_t
code
=
TSDB_CODE_SUCCESS
;
SQueryPlan
*
pPlan
=
nodesMakeNode
(
QUERY_NODE_PHYSICAL_PLAN
);
CHECK_ALLOC
(
pPlan
,
NULL
);
pPlan
->
pSubplans
=
nodesMakeList
();
if
(
NULL
==
pPlan
->
pSubplans
)
{
nodesDestroyNode
(
pPlan
);
return
NULL
;
}
pPlan
->
queryId
=
pCxt
->
pPlanCxt
->
queryId
;
return
pPlan
;
}
static
int32_t
doBuildPhysiPlan
(
SPhysiPlanContext
*
pCxt
,
SSubLogicPlan
*
pLogicSubplan
,
SSubplan
*
pParent
,
SQueryPlan
*
pQueryPlan
)
{
SNode
*
pSubplan
=
NULL
;
SSubplan
*
pSubplan
=
createPhysiSubplan
(
pCxt
,
pLogicSubplan
);
FOREACH
(
pSubplan
,
pLogicPlan
->
pTopSubplans
)
{
CHECK_ALLOC
(
pSubplan
,
TSDB_CODE_OUT_OF_MEMORY
);
code
=
buildPhysiPlan
(
pCxt
,
(
SLogicSubplan
*
)
pSubplan
,
NULL
,
pPlan
);
CHECK_CODE_EXT
(
pushSubplan
(
pCxt
,
pSubplan
,
pLogicSubplan
->
level
,
pQueryPlan
->
pSubplans
));
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
++
(
pQueryPlan
->
numOfSubplans
);
break
;
if
(
NULL
!=
pParent
)
{
}
CHECK_CODE_EXT
(
appendWithMakeList
(
&
pParent
->
pChildren
,
pSubplan
));
CHECK_CODE_EXT
(
appendWithMakeList
(
&
pSubplan
->
pParents
,
pParent
));
}
}
SNode
*
pChild
=
NULL
;
if
(
TSDB_CODE_SUCCESS
==
code
)
{
FOREACH
(
pChild
,
pLogicSubplan
->
pChildren
)
{
*
pPhysiPlan
=
pPlan
;
CHECK_CODE_EXT
(
doBuildPhysiPlan
(
pCxt
,
(
SSubLogicPlan
*
)
pChild
,
pSubplan
,
pQueryPlan
));
}
else
{
nodesDestroyNode
(
pPlan
);
}
}
return
TSDB_CODE_SUCCESS
;
return
code
;
}
static
int32_t
buildPhysiPlan
(
SPhysiPlanContext
*
pCxt
,
SQueryLogicPlan
*
pLogicPlan
,
SQueryPlan
**
pPlan
)
{
*
pPlan
=
makeQueryPhysiPlan
(
pCxt
);
CHECK_ALLOC
(
*
pPlan
,
TSDB_CODE_OUT_OF_MEMORY
);
SNode
*
pSubplan
=
NULL
;
FOREACH
(
pSubplan
,
pLogicPlan
->
pTopSubplans
)
{
CHECK_CODE_EXT
(
doBuildPhysiPlan
(
pCxt
,
(
SSubLogicPlan
*
)
pSubplan
,
NULL
,
*
pPlan
));
}
return
TSDB_CODE_SUCCESS
;
}
}
int32_t
createPhysiPlan
(
SPlanContext
*
pCxt
,
S
LogicNode
*
pLogicNode
,
SQueryPlan
**
pPlan
,
SArray
*
pExecNodeList
)
{
int32_t
createPhysiPlan
(
SPlanContext
*
pCxt
,
S
QueryLogicPlan
*
pLogicPlan
,
SQueryPlan
**
pPlan
,
SArray
*
pExecNodeList
)
{
SPhysiPlanContext
cxt
=
{
SPhysiPlanContext
cxt
=
{
.
pPlanCxt
=
pCxt
,
.
pPlanCxt
=
pCxt
,
.
errCode
=
TSDB_CODE_SUCCESS
,
.
errCode
=
TSDB_CODE_SUCCESS
,
...
@@ -902,16 +929,5 @@ int32_t createPhysiPlan(SPlanContext* pCxt, SLogicNode* pLogicNode, SQueryPlan**
...
@@ -902,16 +929,5 @@ int32_t createPhysiPlan(SPlanContext* pCxt, SLogicNode* pLogicNode, SQueryPlan**
if
(
NULL
==
cxt
.
pLocationHelper
)
{
if
(
NULL
==
cxt
.
pLocationHelper
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
SQueryLogicPlan
*
pLogicPlan
=
NULL
;
return
doCreatePhysiPlan
(
&
cxt
,
pLogicPlan
,
pPlan
);
SSubLogicPlan
*
pSubLogicPlan
=
NULL
;
int32_t
code
=
splitLogicPlan
(
&
cxt
,
pLogicNode
,
&
pSubLogicPlan
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
scaleOutLogicPlan
(
&
cxt
,
pSubLogicPlan
,
&
pLogicPlan
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
buildPhysiPlan
(
&
cxt
,
pLogicPlan
,
pPlan
);
}
nodesDestroyNode
(
pSubLogicPlan
);
nodesDestroyNode
(
pLogicPlan
);
return
code
;
}
}
source/libs/planner/src/planScaleOut.c
0 → 100644
浏览文件 @
c3e098d7
/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "planInt.h"
typedef
struct
SScaleOutContext
{
SPlanContext
*
pPlanCxt
;
int32_t
subplanId
;
}
SScaleOutContext
;
static
SLogicSubplan
*
singleCloneSubLogicPlan
(
SScaleOutContext
*
pCxt
,
SLogicSubplan
*
pSrc
,
int32_t
level
)
{
SLogicSubplan
*
pDst
=
nodesMakeNode
(
QUERY_NODE_LOGIC_SUBPLAN
);
if
(
NULL
==
pDst
)
{
return
NULL
;
}
pDst
->
pNode
=
nodesCloneNode
(
pSrc
->
pNode
);
if
(
NULL
==
pDst
->
pNode
)
{
nodesDestroyNode
(
pDst
);
return
NULL
;
}
pDst
->
subplanType
=
pSrc
->
subplanType
;
pDst
->
level
=
level
;
pDst
->
id
.
queryId
=
pSrc
->
id
.
queryId
;
pDst
->
id
.
groupId
=
pSrc
->
id
.
groupId
;
pDst
->
id
.
subplanId
=
pCxt
->
subplanId
++
;
return
pDst
;
}
static
int32_t
scaleOutForModify
(
SScaleOutContext
*
pCxt
,
SLogicSubplan
*
pSubplan
,
int32_t
level
,
SNodeList
*
pGroup
)
{
SVnodeModifLogicNode
*
pNode
=
(
SVnodeModifLogicNode
*
)
pSubplan
->
pNode
;
size_t
numOfVgroups
=
taosArrayGetSize
(
pNode
->
pDataBlocks
);
for
(
int32_t
i
=
0
;
i
<
numOfVgroups
;
++
i
)
{
SLogicSubplan
*
pNewSubplan
=
singleCloneSubLogicPlan
(
pCxt
,
pSubplan
,
level
);
if
(
NULL
==
pNewSubplan
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
((
SVnodeModifLogicNode
*
)
pNewSubplan
->
pNode
)
->
pVgDataBlocks
=
(
SVgDataBlocks
*
)
taosArrayGetP
(
pNode
->
pDataBlocks
,
i
);
if
(
TSDB_CODE_SUCCESS
!=
nodesListStrictAppend
(
pGroup
,
pNewSubplan
))
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
scaleOutForMerge
(
SScaleOutContext
*
pCxt
,
SLogicSubplan
*
pSubplan
,
int32_t
level
,
SNodeList
*
pGroup
)
{
return
nodesListStrictAppend
(
pGroup
,
singleCloneSubLogicPlan
(
pCxt
,
pSubplan
,
level
));
}
static
int32_t
doSetScanVgroup
(
SLogicNode
*
pNode
,
const
SVgroupInfo
*
pVgroup
,
bool
*
pFound
)
{
if
(
QUERY_NODE_LOGIC_PLAN_SCAN
==
nodeType
(
pNode
))
{
SScanLogicNode
*
pScan
=
(
SScanLogicNode
*
)
pNode
;
pScan
->
pVgroupList
=
calloc
(
1
,
sizeof
(
SVgroupsInfo
)
+
sizeof
(
SVgroupInfo
));
if
(
NULL
==
pScan
->
pVgroupList
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
memcpy
(
pScan
->
pVgroupList
->
vgroups
,
pVgroup
,
sizeof
(
SVgroupInfo
));
*
pFound
=
true
;
return
TSDB_CODE_SUCCESS
;
}
SNode
*
pChild
=
NULL
;
FOREACH
(
pChild
,
pNode
->
pChildren
)
{
int32_t
code
=
doSetScanVgroup
((
SLogicNode
*
)
pChild
,
pVgroup
,
pFound
);
if
(
TSDB_CODE_SUCCESS
!=
code
||
*
pFound
)
{
return
code
;
}
}
return
TSDB_CODE_SUCCESS
;
}
static
int32_t
setScanVgroup
(
SLogicNode
*
pNode
,
const
SVgroupInfo
*
pVgroup
)
{
bool
found
=
false
;
return
doSetScanVgroup
(
pNode
,
pVgroup
,
&
found
);
}
static
int32_t
scaleOutForScan
(
SScaleOutContext
*
pCxt
,
SLogicSubplan
*
pSubplan
,
int32_t
level
,
SNodeList
*
pGroup
)
{
if
(
pSubplan
->
pVgroupList
)
{
int32_t
code
=
TSDB_CODE_SUCCESS
;
for
(
int32_t
i
=
0
;
i
<
pSubplan
->
pVgroupList
->
numOfVgroups
;
++
i
)
{
SLogicSubplan
*
pNewSubplan
=
singleCloneSubLogicPlan
(
pCxt
,
pSubplan
,
level
);
if
(
NULL
==
pNewSubplan
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
code
=
setScanVgroup
(
pNewSubplan
->
pNode
,
pSubplan
->
pVgroupList
->
vgroups
+
i
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodesListStrictAppend
(
pGroup
,
pNewSubplan
);
}
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
break
;
}
}
return
code
;
}
else
{
return
scaleOutForMerge
(
pCxt
,
pSubplan
,
level
,
pGroup
);
}
}
static
int32_t
pushHierarchicalPlan
(
SNodeList
*
pParentsGroup
,
SNodeList
*
pCurrentGroup
)
{
int32_t
code
=
TSDB_CODE_SUCCESS
;
bool
topLevel
=
(
0
==
LIST_LENGTH
(
pParentsGroup
));
SNode
*
pChild
=
NULL
;
FOREACH
(
pChild
,
pCurrentGroup
)
{
if
(
topLevel
)
{
code
=
nodesListAppend
(
pParentsGroup
,
pChild
);
}
else
{
SNode
*
pParent
=
NULL
;
FOREACH
(
pParent
,
pParentsGroup
)
{
code
=
nodesListMakeAppend
(
&
(((
SLogicSubplan
*
)
pParent
)
->
pChildren
),
pChild
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
nodesListMakeAppend
(
&
(((
SLogicSubplan
*
)
pChild
)
->
pParents
),
pParent
);
}
}
}
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
break
;
}
}
return
code
;
}
static
int32_t
doScaleOut
(
SScaleOutContext
*
pCxt
,
SLogicSubplan
*
pSubplan
,
int32_t
*
pLevel
,
SNodeList
*
pParentsGroup
)
{
SNodeList
*
pCurrentGroup
=
nodesMakeList
();
if
(
NULL
==
pCurrentGroup
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
int32_t
code
=
TSDB_CODE_SUCCESS
;
switch
(
pSubplan
->
subplanType
)
{
case
SUBPLAN_TYPE_MERGE
:
code
=
scaleOutForMerge
(
pCxt
,
pSubplan
,
*
pLevel
,
pCurrentGroup
);
break
;
case
SUBPLAN_TYPE_SCAN
:
code
=
scaleOutForScan
(
pCxt
,
pSubplan
,
*
pLevel
,
pCurrentGroup
);
break
;
case
SUBPLAN_TYPE_MODIFY
:
code
=
scaleOutForModify
(
pCxt
,
pSubplan
,
*
pLevel
,
pCurrentGroup
);
break
;
default:
break
;
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
pushHierarchicalPlan
(
pParentsGroup
,
pCurrentGroup
);
++
(
*
pLevel
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
SNode
*
pChild
;
FOREACH
(
pChild
,
pSubplan
->
pChildren
)
{
code
=
doScaleOut
(
pCxt
,
(
SLogicSubplan
*
)
pChild
,
pLevel
,
pCurrentGroup
);
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
break
;
}
}
}
if
(
TSDB_CODE_SUCCESS
!=
code
)
{
nodesDestroyList
(
pCurrentGroup
);
}
return
code
;
}
static
SQueryLogicPlan
*
makeQueryLogicPlan
()
{
SQueryLogicPlan
*
pLogicPlan
=
(
SQueryLogicPlan
*
)
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN
);
if
(
NULL
==
pLogicPlan
)
{
return
NULL
;
}
pLogicPlan
->
pTopSubplans
=
nodesMakeList
();
if
(
NULL
==
pLogicPlan
->
pTopSubplans
)
{
nodesDestroyNode
(
pLogicPlan
);
return
NULL
;
}
return
pLogicPlan
;
}
int32_t
scaleOutLogicPlan
(
SPlanContext
*
pCxt
,
SLogicSubplan
*
pLogicSubplan
,
SQueryLogicPlan
**
pLogicPlan
)
{
SQueryLogicPlan
*
pPlan
=
makeQueryLogicPlan
();
if
(
NULL
==
pPlan
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
SScaleOutContext
cxt
=
{
.
pPlanCxt
=
pCxt
,
.
subplanId
=
1
};
int32_t
code
=
doScaleOut
(
&
cxt
,
pLogicSubplan
,
&
(
pPlan
->
totalLevel
),
pPlan
->
pTopSubplans
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pLogicPlan
=
pPlan
;
}
else
{
nodesDestroyNode
(
pPlan
);
}
return
code
;
}
source/libs/planner/src/planSpliter.c
浏览文件 @
c3e098d7
...
@@ -29,7 +29,7 @@ typedef struct SSplitContext {
...
@@ -29,7 +29,7 @@ typedef struct SSplitContext {
void
*
pInfo
;
void
*
pInfo
;
}
SSplitContext
;
}
SSplitContext
;
typedef
int32_t
(
*
FMatch
)(
SSplitContext
*
pCxt
,
S
SubLogicP
lan
*
pSubplan
);
typedef
int32_t
(
*
FMatch
)(
SSplitContext
*
pCxt
,
S
LogicSubp
lan
*
pSubplan
);
typedef
int32_t
(
*
FSplit
)(
SSplitContext
*
pCxt
);
typedef
int32_t
(
*
FSplit
)(
SSplitContext
*
pCxt
);
typedef
struct
SSplitRule
{
typedef
struct
SSplitRule
{
...
@@ -40,7 +40,7 @@ typedef struct SSplitRule {
...
@@ -40,7 +40,7 @@ typedef struct SSplitRule {
typedef
struct
SStsInfo
{
typedef
struct
SStsInfo
{
SScanLogicNode
*
pScan
;
SScanLogicNode
*
pScan
;
S
SubLogicP
lan
*
pSubplan
;
S
LogicSubp
lan
*
pSubplan
;
}
SStsInfo
;
}
SStsInfo
;
static
SLogicNode
*
stsMatchByNode
(
SLogicNode
*
pNode
)
{
static
SLogicNode
*
stsMatchByNode
(
SLogicNode
*
pNode
)
{
...
@@ -58,7 +58,7 @@ static SLogicNode* stsMatchByNode(SLogicNode* pNode) {
...
@@ -58,7 +58,7 @@ static SLogicNode* stsMatchByNode(SLogicNode* pNode) {
return
NULL
;
return
NULL
;
}
}
static
int32_t
stsMatch
(
SSplitContext
*
pCxt
,
S
SubLogicP
lan
*
pSubplan
)
{
static
int32_t
stsMatch
(
SSplitContext
*
pCxt
,
S
LogicSubp
lan
*
pSubplan
)
{
if
(
SPLIT_FLAG_TEST_MASK
(
pSubplan
->
splitFlag
,
SPLIT_FLAG_STS
))
{
if
(
SPLIT_FLAG_TEST_MASK
(
pSubplan
->
splitFlag
,
SPLIT_FLAG_STS
))
{
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
...
@@ -74,7 +74,7 @@ static int32_t stsMatch(SSplitContext* pCxt, SSubLogicPlan* pSubplan) {
...
@@ -74,7 +74,7 @@ static int32_t stsMatch(SSplitContext* pCxt, SSubLogicPlan* pSubplan) {
}
}
SNode
*
pChild
;
SNode
*
pChild
;
FOREACH
(
pChild
,
pSubplan
->
pChildren
)
{
FOREACH
(
pChild
,
pSubplan
->
pChildren
)
{
int32_t
code
=
stsMatch
(
pCxt
,
(
S
SubLogicP
lan
*
)
pChild
);
int32_t
code
=
stsMatch
(
pCxt
,
(
S
LogicSubp
lan
*
)
pChild
);
if
(
TSDB_CODE_SUCCESS
!=
code
||
pCxt
->
match
)
{
if
(
TSDB_CODE_SUCCESS
!=
code
||
pCxt
->
match
)
{
return
code
;
return
code
;
}
}
...
@@ -82,8 +82,8 @@ static int32_t stsMatch(SSplitContext* pCxt, SSubLogicPlan* pSubplan) {
...
@@ -82,8 +82,8 @@ static int32_t stsMatch(SSplitContext* pCxt, SSubLogicPlan* pSubplan) {
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
static
S
SubLogicP
lan
*
stsCreateScanSubplan
(
SSplitContext
*
pCxt
,
SScanLogicNode
*
pScan
)
{
static
S
LogicSubp
lan
*
stsCreateScanSubplan
(
SSplitContext
*
pCxt
,
SScanLogicNode
*
pScan
)
{
S
SubLogicP
lan
*
pSubplan
=
nodesMakeNode
(
QUERY_NODE_LOGIC_SUBPLAN
);
S
LogicSubp
lan
*
pSubplan
=
nodesMakeNode
(
QUERY_NODE_LOGIC_SUBPLAN
);
if
(
NULL
==
pSubplan
)
{
if
(
NULL
==
pSubplan
)
{
return
NULL
;
return
NULL
;
}
}
...
@@ -95,7 +95,7 @@ static SSubLogicPlan* stsCreateScanSubplan(SSplitContext* pCxt, SScanLogicNode*
...
@@ -95,7 +95,7 @@ static SSubLogicPlan* stsCreateScanSubplan(SSplitContext* pCxt, SScanLogicNode*
return
pSubplan
;
return
pSubplan
;
}
}
static
int32_t
stsCreateExchangeNode
(
SSplitContext
*
pCxt
,
S
SubLogicP
lan
*
pSubplan
,
SScanLogicNode
*
pScan
)
{
static
int32_t
stsCreateExchangeNode
(
SSplitContext
*
pCxt
,
S
LogicSubp
lan
*
pSubplan
,
SScanLogicNode
*
pScan
)
{
SExchangeLogicNode
*
pExchange
=
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN_EXCHANGE
);
SExchangeLogicNode
*
pExchange
=
nodesMakeNode
(
QUERY_NODE_LOGIC_PLAN_EXCHANGE
);
if
(
NULL
==
pExchange
)
{
if
(
NULL
==
pExchange
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
return
TSDB_CODE_OUT_OF_MEMORY
;
...
@@ -145,7 +145,7 @@ static const SSplitRule splitRuleSet[] = {
...
@@ -145,7 +145,7 @@ static const SSplitRule splitRuleSet[] = {
static
const
int32_t
splitRuleNum
=
(
sizeof
(
splitRuleSet
)
/
sizeof
(
SSplitRule
));
static
const
int32_t
splitRuleNum
=
(
sizeof
(
splitRuleSet
)
/
sizeof
(
SSplitRule
));
int32_t
applySplitRule
(
SSubLogicP
lan
*
pSubplan
)
{
static
int32_t
applySplitRule
(
SLogicSubp
lan
*
pSubplan
)
{
SSplitContext
cxt
=
{
.
errCode
=
TSDB_CODE_SUCCESS
,
.
groupId
=
pSubplan
->
id
.
groupId
+
1
,
.
match
=
false
,
.
pInfo
=
NULL
};
SSplitContext
cxt
=
{
.
errCode
=
TSDB_CODE_SUCCESS
,
.
groupId
=
pSubplan
->
id
.
groupId
+
1
,
.
match
=
false
,
.
pInfo
=
NULL
};
bool
split
=
false
;
bool
split
=
false
;
do
{
do
{
...
@@ -164,3 +164,45 @@ int32_t applySplitRule(SSubLogicPlan* pSubplan) {
...
@@ -164,3 +164,45 @@ int32_t applySplitRule(SSubLogicPlan* pSubplan) {
}
while
(
split
);
}
while
(
split
);
return
TSDB_CODE_SUCCESS
;
return
TSDB_CODE_SUCCESS
;
}
}
static
void
doSetLogicNodeParent
(
SLogicNode
*
pNode
,
SLogicNode
*
pParent
)
{
pNode
->
pParent
=
pParent
;
SNode
*
pChild
;
FOREACH
(
pChild
,
pNode
->
pChildren
)
{
doSetLogicNodeParent
((
SLogicNode
*
)
pChild
,
pNode
);
}
}
static
void
setLogicNodeParent
(
SLogicNode
*
pNode
)
{
doSetLogicNodeParent
(
pNode
,
NULL
);
}
int32_t
splitLogicPlan
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
,
SLogicSubplan
**
pLogicSubplan
)
{
SLogicSubplan
*
pSubplan
=
(
SLogicSubplan
*
)
nodesMakeNode
(
QUERY_NODE_LOGIC_SUBPLAN
);
if
(
NULL
==
pSubplan
)
{
return
TSDB_CODE_OUT_OF_MEMORY
;
}
pSubplan
->
pNode
=
nodesCloneNode
(
pLogicNode
);
if
(
NULL
==
pSubplan
->
pNode
)
{
nodesDestroyNode
(
pSubplan
);
return
TSDB_CODE_OUT_OF_MEMORY
;
}
if
(
QUERY_NODE_LOGIC_PLAN_VNODE_MODIF
==
nodeType
(
pLogicNode
))
{
pSubplan
->
subplanType
=
SUBPLAN_TYPE_MODIFY
;
TSWAP
(((
SVnodeModifLogicNode
*
)
pLogicNode
)
->
pDataBlocks
,
((
SVnodeModifLogicNode
*
)
pSubplan
->
pNode
)
->
pDataBlocks
,
SArray
*
);
}
else
{
pSubplan
->
subplanType
=
SUBPLAN_TYPE_SCAN
;
}
pSubplan
->
id
.
queryId
=
pCxt
->
queryId
;
setLogicNodeParent
(
pSubplan
->
pNode
);
int32_t
code
=
applySplitRule
(
pSubplan
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
*
pLogicSubplan
=
pSubplan
;
}
else
{
nodesDestroyNode
(
pSubplan
);
}
return
code
;
}
\ No newline at end of file
source/libs/planner/src/planner.c
浏览文件 @
c3e098d7
...
@@ -17,20 +17,29 @@
...
@@ -17,20 +17,29 @@
#include "planInt.h"
#include "planInt.h"
int32_t
optimize
(
SPlanContext
*
pCxt
,
SLogicNode
*
pLogicNode
)
{
return
TSDB_CODE_SUCCESS
;
}
int32_t
qCreateQueryPlan
(
SPlanContext
*
pCxt
,
SQueryPlan
**
pPlan
,
SArray
*
pExecNodeList
)
{
int32_t
qCreateQueryPlan
(
SPlanContext
*
pCxt
,
SQueryPlan
**
pPlan
,
SArray
*
pExecNodeList
)
{
SLogicNode
*
pLogicNode
=
NULL
;
SLogicNode
*
pLogicNode
=
NULL
;
SLogicSubplan
*
pLogicSubplan
=
NULL
;
SQueryLogicPlan
*
pLogicPlan
=
NULL
;
int32_t
code
=
createLogicPlan
(
pCxt
,
&
pLogicNode
);
int32_t
code
=
createLogicPlan
(
pCxt
,
&
pLogicNode
);
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
optimize
(
pCxt
,
pLogicNode
);
code
=
optimizeLogicPlan
(
pCxt
,
pLogicNode
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
splitLogicPlan
(
pCxt
,
pLogicNode
,
&
pLogicSubplan
);
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
scaleOutLogicPlan
(
pCxt
,
pLogicSubplan
,
&
pLogicPlan
);
}
}
if
(
TSDB_CODE_SUCCESS
==
code
)
{
if
(
TSDB_CODE_SUCCESS
==
code
)
{
code
=
createPhysiPlan
(
pCxt
,
pLogic
Node
,
pPlan
,
pExecNodeList
);
code
=
createPhysiPlan
(
pCxt
,
pLogic
Plan
,
pPlan
,
pExecNodeList
);
}
}
nodesDestroyNode
(
pLogicNode
);
nodesDestroyNode
(
pLogicNode
);
nodesDestroyNode
(
pLogicSubplan
);
nodesDestroyNode
(
pLogicPlan
);
terrno
=
code
;
return
code
;
return
code
;
}
}
...
...
source/libs/planner/test/plannerTest.cpp
浏览文件 @
c3e098d7
...
@@ -26,11 +26,6 @@ using namespace testing;
...
@@ -26,11 +26,6 @@ using namespace testing;
class
PlannerTest
:
public
Test
{
class
PlannerTest
:
public
Test
{
protected:
protected:
enum
TestTarget
{
TEST_LOGIC_PLAN
,
TEST_PHYSICAL_PLAN
};
void
setDatabase
(
const
string
&
acctId
,
const
string
&
db
)
{
void
setDatabase
(
const
string
&
acctId
,
const
string
&
db
)
{
acctId_
=
acctId
;
acctId_
=
acctId
;
db_
=
db
;
db_
=
db
;
...
@@ -46,7 +41,7 @@ protected:
...
@@ -46,7 +41,7 @@ protected:
cxt_
.
pSql
=
sqlBuf_
.
c_str
();
cxt_
.
pSql
=
sqlBuf_
.
c_str
();
}
}
bool
run
(
TestTarget
target
=
TEST_PHYSICAL_PLAN
)
{
bool
run
()
{
int32_t
code
=
qParseQuerySql
(
&
cxt_
,
&
query_
);
int32_t
code
=
qParseQuerySql
(
&
cxt_
,
&
query_
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
...
@@ -56,12 +51,12 @@ protected:
...
@@ -56,12 +51,12 @@ protected:
const
string
syntaxTreeStr
=
toString
(
query_
->
pRoot
,
false
);
const
string
syntaxTreeStr
=
toString
(
query_
->
pRoot
,
false
);
SLogicNode
*
pLogic
Plan
=
nullptr
;
SLogicNode
*
pLogic
Node
=
nullptr
;
SPlanContext
cxt
=
{
.
queryId
=
1
,
.
acctId
=
0
};
SPlanContext
cxt
=
{
.
queryId
=
1
,
.
acctId
=
0
};
setPlanContext
(
query_
,
&
cxt
);
setPlanContext
(
query_
,
&
cxt
);
code
=
createLogicPlan
(
&
cxt
,
&
pLogic
Plan
);
code
=
createLogicPlan
(
&
cxt
,
&
pLogic
Node
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"]
logic p
lan code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"]
createLogicP
lan code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
return
false
;
return
false
;
}
}
...
@@ -69,24 +64,37 @@ protected:
...
@@ -69,24 +64,37 @@ protected:
cout
<<
"syntax test : "
<<
endl
;
cout
<<
"syntax test : "
<<
endl
;
cout
<<
syntaxTreeStr
<<
endl
;
cout
<<
syntaxTreeStr
<<
endl
;
cout
<<
"unformatted logic plan : "
<<
endl
;
cout
<<
"unformatted logic plan : "
<<
endl
;
cout
<<
toString
((
const
SNode
*
)
pLogicPlan
,
false
)
<<
endl
;
cout
<<
toString
((
const
SNode
*
)
pLogicNode
,
false
)
<<
endl
;
if
(
TEST_PHYSICAL_PLAN
==
target
)
{
SLogicSubplan
*
pLogicSubplan
=
nullptr
;
SQueryPlan
*
pPlan
=
nullptr
;
code
=
splitLogicPlan
(
&
cxt
,
pLogicNode
,
&
pLogicSubplan
);
code
=
createPhysiPlan
(
&
cxt
,
pLogicPlan
,
&
pPlan
,
NULL
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] splitLogicPlan code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] physical plan code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
return
false
;
return
false
;
}
}
cout
<<
"unformatted physical plan : "
<<
endl
;
SQueryLogicPlan
*
pLogicPlan
=
NULL
;
cout
<<
toString
((
const
SNode
*
)
pPlan
,
false
)
<<
endl
;
code
=
scaleOutLogicPlan
(
&
cxt
,
pLogicSubplan
,
&
pLogicPlan
);
SNode
*
pNode
;
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
FOREACH
(
pNode
,
pPlan
->
pSubplans
)
{
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] createPhysiPlan code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
SNode
*
pSubplan
;
return
false
;
FOREACH
(
pSubplan
,
((
SNodeListNode
*
)
pNode
)
->
pNodeList
)
{
}
cout
<<
"unformatted physical subplan : "
<<
endl
;
cout
<<
toString
(
pSubplan
,
false
)
<<
endl
;
SQueryPlan
*
pPlan
=
nullptr
;
}
code
=
createPhysiPlan
(
&
cxt
,
pLogicPlan
,
&
pPlan
,
NULL
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] createPhysiPlan code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
return
false
;
}
cout
<<
"unformatted physical plan : "
<<
endl
;
cout
<<
toString
((
const
SNode
*
)
pPlan
,
false
)
<<
endl
;
SNode
*
pNode
;
FOREACH
(
pNode
,
pPlan
->
pSubplans
)
{
SNode
*
pSubplan
;
FOREACH
(
pSubplan
,
((
SNodeListNode
*
)
pNode
)
->
pNodeList
)
{
cout
<<
"unformatted physical subplan : "
<<
endl
;
cout
<<
toString
(
pSubplan
,
false
)
<<
endl
;
}
}
}
}
...
@@ -120,14 +128,6 @@ private:
...
@@ -120,14 +128,6 @@ private:
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] toString code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] toString code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
return
string
();
return
string
();
}
}
SNode
*
pNode
;
code
=
nodesStringToNode
(
pStr
,
&
pNode
);
if
(
code
!=
TSDB_CODE_SUCCESS
)
{
tfree
(
pStr
);
cout
<<
"sql:["
<<
cxt_
.
pSql
<<
"] toObject code:"
<<
code
<<
", strerror:"
<<
tstrerror
(
code
)
<<
endl
;
return
string
();
}
nodesDestroyNode
(
pNode
);
string
str
(
pStr
);
string
str
(
pStr
);
tfree
(
pStr
);
tfree
(
pStr
);
return
str
;
return
str
;
...
@@ -185,6 +185,13 @@ TEST_F(PlannerTest, interval) {
...
@@ -185,6 +185,13 @@ TEST_F(PlannerTest, interval) {
ASSERT_TRUE
(
run
());
ASSERT_TRUE
(
run
());
}
}
TEST_F
(
PlannerTest
,
sessionWindow
)
{
setDatabase
(
"root"
,
"test"
);
bind
(
"SELECT count(*) FROM t1 session(ts, 10s)"
);
ASSERT_TRUE
(
run
());
}
TEST_F
(
PlannerTest
,
showTables
)
{
TEST_F
(
PlannerTest
,
showTables
)
{
setDatabase
(
"root"
,
"test"
);
setDatabase
(
"root"
,
"test"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录