Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
6f3be9fe
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
Star
22018
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
6f3be9fe
编写于
11月 08, 2021
作者:
S
shenglian zhou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
support concat with more than two columns
上级
67873662
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
115 addition
and
39 deletion
+115
-39
src/common/inc/texpr.h
src/common/inc/texpr.h
+2
-1
src/common/src/texpr.c
src/common/src/texpr.c
+113
-38
未找到文件。
src/common/inc/texpr.h
浏览文件 @
6f3be9fe
...
...
@@ -50,7 +50,8 @@ struct SSchema;
#define TSDB_FUNC_SCALAR_POW (TSDB_FUNC_FLAG_SCALAR | 0x0000)
#define TSDB_FUNC_SCALAR_LOG (TSDB_FUNC_FLAG_SCALAR | 0x0001)
#define TSDB_FUNC_SCALAR_CONCAT (TSDB_FUNC_FLAG_SCALAR | 0x0002)
#define TSDB_FUNC_SCALAR_MAX_NUM 3
#define TSDB_FUNC_SCALAR_LENGTH (TSDB_FUNC_FLAG_SCALAR | 0x0003)
#define TSDB_FUNC_SCALAR_MAX_NUM 4
#define TSDB_FUNC_SCALAR_NAME_MAX_LEN 16
typedef
struct
{
...
...
src/common/src/texpr.c
浏览文件 @
6f3be9fe
...
...
@@ -60,37 +60,79 @@ int32_t exprTreeValidateFunctionNode(tExprNode *pExpr) {
break
;
}
case
TSDB_FUNC_SCALAR_CONCAT
:
{
if
(
pExpr
->
_func
.
numChildren
!=
2
)
{
if
(
pExpr
->
_func
.
numChildren
<
2
)
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
tExprNode
*
child1
=
pExpr
->
_func
.
pChildren
[
0
];
tExprNode
*
child2
=
pExpr
->
_func
.
pChildren
[
1
];
if
(
child1
->
nodeType
==
TSQL_NODE_VALUE
)
{
if
(
!
IS_VAR_DATA_TYPE
(
child1
->
resultType
))
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
int16_t
prevResultType
=
TSDB_DATA_TYPE_NULL
;
int16_t
resultType
=
TSDB_DATA_TYPE_NULL
;
bool
resultTypeAlreadySet
=
false
;
for
(
int32_t
i
=
0
;
i
<
pExpr
->
_func
.
numChildren
;
++
i
)
{
tExprNode
*
child
=
pExpr
->
_func
.
pChildren
[
i
];
if
(
child
->
nodeType
!=
TSQL_NODE_VALUE
)
{
resultType
=
child
->
resultType
;
if
(
!
IS_VAR_DATA_TYPE
(
resultType
))
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
if
(
!
resultTypeAlreadySet
)
{
resultTypeAlreadySet
=
true
;
}
else
{
if
(
resultType
!=
prevResultType
)
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
}
prevResultType
=
child
->
resultType
;
}
tVariantTypeSetType
(
child1
->
pVal
,
(
char
)(
child1
->
resultType
));
child1
->
resultType
=
(
int16_t
)
child2
->
pVal
->
nType
;
child1
->
resultBytes
=
(
int16_t
)(
child2
->
pVal
->
nLen
+
VARSTR_HEADER_SIZE
);
}
if
(
child2
->
nodeType
==
TSQL_NODE_VALUE
)
{
if
(
!
IS_VAR_DATA_TYPE
(
child2
->
pVal
->
nType
))
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
if
(
resultTypeAlreadySet
)
{
for
(
int32_t
i
=
0
;
i
<
pExpr
->
_func
.
numChildren
;
++
i
)
{
tExprNode
*
child
=
pExpr
->
_func
.
pChildren
[
i
];
if
(
child
->
nodeType
==
TSQL_NODE_VALUE
)
{
if
(
!
IS_VAR_DATA_TYPE
(
child
->
pVal
->
nType
))
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
tVariantTypeSetType
(
child
->
pVal
,
(
char
)
resultType
);
child
->
resultType
=
resultType
;
child
->
resultBytes
=
(
int16_t
)(
child
->
pVal
->
nLen
+
VARSTR_HEADER_SIZE
);
}
}
tVariantTypeSetType
(
child2
->
pVal
,
(
char
)(
child1
->
resultType
));
child2
->
resultType
=
(
int16_t
)
child2
->
pVal
->
nType
;
child2
->
resultBytes
=
(
int16_t
)(
child2
->
pVal
->
nLen
+
VARSTR_HEADER_SIZE
);
}
else
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
if
(
child1
->
resultType
!=
child2
->
resultType
||
(
!
IS_VAR_DATA_TYPE
(
child1
->
resultType
)))
{
pExpr
->
resultType
=
resultType
;
int16_t
resultBytes
=
0
;
for
(
int32_t
i
=
0
;
i
<
pExpr
->
_func
.
numChildren
;
++
i
)
{
tExprNode
*
child
=
pExpr
->
_func
.
pChildren
[
i
];
if
(
resultBytes
<=
resultBytes
+
child
->
resultBytes
-
VARSTR_HEADER_SIZE
)
{
resultBytes
+=
child
->
resultBytes
-
VARSTR_HEADER_SIZE
;
}
else
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
}
pExpr
->
resultBytes
=
resultBytes
+
VARSTR_HEADER_SIZE
;
break
;
}
case
TSDB_FUNC_SCALAR_LENGTH
:
{
if
(
pExpr
->
_func
.
numChildren
!=
1
)
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
pExpr
->
resultType
=
child1
->
resultType
;
pExpr
->
resultBytes
=
child1
->
resultBytes
+
child2
->
resultBytes
-
VARSTR_HEADER_SIZE
;
tExprNode
*
child1
=
pExpr
->
_func
.
pChildren
[
0
];
if
(
child1
->
nodeType
==
TSQL_NODE_VALUE
)
{
if
(
!
IS_VAR_DATA_TYPE
(
child1
->
pVal
->
nType
))
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
tVariantTypeSetType
(
child1
->
pVal
,
(
char
)(
child1
->
resultType
));
child1
->
resultType
=
(
int16_t
)
child1
->
pVal
->
nType
;
child1
->
resultBytes
=
(
int16_t
)(
child1
->
pVal
->
nLen
+
VARSTR_HEADER_SIZE
);
}
if
(
!
IS_VAR_DATA_TYPE
(
child1
->
resultType
))
break
;
}
default:
break
;
}
...
...
@@ -936,38 +978,66 @@ void vectorLog(int16_t functionId, tExprOperandInfo* pInputs, uint8_t numInputs,
}
void
vectorConcat
(
int16_t
functionId
,
tExprOperandInfo
*
pInputs
,
uint8_t
numInputs
,
tExprOperandInfo
*
pOutput
,
int32_t
order
)
{
assert
(
functionId
==
TSDB_FUNC_SCALAR_CONCAT
&&
numInputs
==
2
&&
order
==
TSDB_ORDER_ASC
);
assert
(
pInputs
[
0
].
numOfRows
>=
1
&&
pInputs
[
1
].
numOfRows
>=
1
);
assert
(
pOutput
->
numOfRows
>=
MAX
(
pInputs
[
0
].
numOfRows
,
pInputs
[
1
].
numOfRows
));
char
*
data0
=
NULL
;
char
*
data1
=
NULL
;
char
*
outputData
=
NULL
;
assert
(
functionId
==
TSDB_FUNC_SCALAR_CONCAT
&&
numInputs
>=
2
&&
order
==
TSDB_ORDER_ASC
);
for
(
int
i
=
0
;
i
<
numInputs
;
++
i
)
{
assert
(
pInputs
[
i
].
numOfRows
==
1
||
pInputs
[
i
].
numOfRows
==
pOutput
->
numOfRows
);
}
char
*
outputData
=
NULL
;
char
**
inputData
=
calloc
(
numInputs
,
sizeof
(
char
*
));
for
(
int
i
=
0
;
i
<
pOutput
->
numOfRows
;
++
i
)
{
if
(
pInputs
[
0
].
numOfRows
==
1
&&
pInputs
[
1
].
numOfRows
==
1
)
{
data0
=
pInputs
[
0
].
data
;
data1
=
pInputs
[
1
].
data
;
}
else
if
(
pInputs
[
0
].
numOfRows
==
1
){
for
(
int
j
=
0
;
j
<
numInputs
;
++
j
)
{
if
(
pInputs
[
j
].
numOfRows
==
1
)
{
inputData
[
j
]
=
pInputs
[
j
].
data
;
}
else
{
inputData
[
j
]
=
pInputs
[
j
].
data
+
i
*
pInputs
[
j
].
bytes
;
}
}
outputData
=
pOutput
->
data
+
i
*
pOutput
->
bytes
;
bool
hasNullInputs
=
false
;
for
(
int
j
=
0
;
j
<
numInputs
;
++
j
)
{
if
(
isNull
(
inputData
[
j
],
pInputs
[
j
].
type
))
{
hasNullInputs
=
true
;
setNull
(
outputData
,
pOutput
->
type
,
pOutput
->
bytes
);
}
}
if
(
!
hasNullInputs
)
{
int16_t
dataLen
=
0
;
for
(
int
j
=
0
;
j
<
numInputs
;
++
j
)
{
memcpy
(
varDataVal
(
outputData
)
+
dataLen
,
varDataVal
(
inputData
[
j
]),
varDataLen
(
inputData
[
j
]));
dataLen
+=
varDataLen
(
inputData
[
j
]);
}
varDataSetLen
(
outputData
,
dataLen
);
}
}
free
(
inputData
);
}
void
vectorLength
(
int16_t
functionId
,
tExprOperandInfo
*
pInputs
,
uint8_t
numInputs
,
tExprOperandInfo
*
pOutput
,
int32_t
order
)
{
assert
(
functionId
==
TSDB_FUNC_SCALAR_LENGTH
&&
numInputs
==
1
&&
order
==
TSDB_ORDER_ASC
);
char
*
data0
=
NULL
;
char
*
outputData
=
NULL
;
for
(
int32_t
i
=
0
;
i
<
pOutput
->
numOfRows
;
++
i
)
{
if
(
pInputs
[
0
].
numOfRows
==
1
)
{
data0
=
pInputs
[
0
].
data
;
data1
=
pInputs
[
1
].
data
+
i
*
pInputs
[
1
].
bytes
;
}
else
if
(
pInputs
[
1
].
numOfRows
==
1
){
data0
=
pInputs
[
0
].
data
+
i
*
pInputs
[
0
].
bytes
;
data1
=
pInputs
[
1
].
data
;
}
else
{
data0
=
pInputs
[
0
].
data
+
i
*
pInputs
[
0
].
bytes
;
data1
=
pInputs
[
1
].
data
+
i
*
pInputs
[
1
].
bytes
;
}
outputData
=
pOutput
->
data
+
i
*
pOutput
->
bytes
;
if
(
isNull
(
data0
,
pInputs
[
0
].
type
)
||
isNull
(
data1
,
pInputs
[
1
].
type
)
)
{
if
(
isNull
(
data0
,
pInputs
[
0
].
type
))
{
setNull
(
outputData
,
pOutput
->
type
,
pOutput
->
bytes
);
}
else
{
varDataSetLen
(
outputData
,
varDataLen
(
data0
)
+
varDataLen
(
data1
));
memcpy
(
varDataVal
(
outputData
),
varDataVal
(
data0
),
varDataLen
(
data0
));
memcpy
(
varDataVal
(
outputData
)
+
varDataLen
(
data0
),
varDataVal
(
data1
),
varDataLen
(
data1
));
int16_t
result
=
varDataLen
(
data0
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
}
}
_expr_scalar_function_t
getExprScalarFunction
(
uint16_t
funcId
)
{
assert
(
TSDB_FUNC_IS_SCALAR
(
funcId
));
int16_t
scalaIdx
=
TSDB_FUNC_SCALAR_INDEX
(
funcId
);
...
...
@@ -991,4 +1061,9 @@ tScalarFunctionInfo aScalarFunctions[] = {
"concat"
,
vectorConcat
},
{
TSDB_FUNC_SCALAR_LENGTH
,
"length"
,
vectorLength
}
};
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录