Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
9aa19d59
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
提交
9aa19d59
编写于
11月 12, 2021
作者:
S
shenglian zhou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
reimplement ceil/floor/round with scalar expr
上级
bb303679
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
112 addition
and
15 deletion
+112
-15
src/common/inc/texpr.h
src/common/inc/texpr.h
+6
-3
src/common/src/texpr.c
src/common/src/texpr.c
+96
-2
src/query/src/qAggMain.c
src/query/src/qAggMain.c
+10
-10
未找到文件。
src/common/inc/texpr.h
浏览文件 @
9aa19d59
...
...
@@ -57,9 +57,12 @@ struct SSchema;
#define TSDB_FUNC_SCALAR_SIN (TSDB_FUNC_FLAG_SCALAR | 0x0007)
#define TSDB_FUNC_SCALAR_TAN (TSDB_FUNC_FLAG_SCALAR | 0x0008)
#define TSDB_FUNC_SCALAR_SQRT (TSDB_FUNC_FLAG_SCALAR | 0x0009)
#define TSDB_FUNC_SCALAR_CONCAT (TSDB_FUNC_FLAG_SCALAR | 0x000A)
#define TSDB_FUNC_SCALAR_LENGTH (TSDB_FUNC_FLAG_SCALAR | 0x000B)
#define TSDB_FUNC_SCALAR_MAX_NUM 12
#define TSDB_FUNC_SCALAR_CEIL (TSDB_FUNC_FLAG_SCALAR | 0x000A)
#define TSDB_FUNC_SCALAR_FLOOR (TSDB_FUNC_FLAG_SCALAR | 0x000B)
#define TSDB_FUNC_SCALAR_ROUND (TSDB_FUNC_FLAG_SCALAR | 0x000C)
#define TSDB_FUNC_SCALAR_CONCAT (TSDB_FUNC_FLAG_SCALAR | 0x000D)
#define TSDB_FUNC_SCALAR_LENGTH (TSDB_FUNC_FLAG_SCALAR | 0x000E)
#define TSDB_FUNC_SCALAR_MAX_NUM 15
#define TSDB_FUNC_SCALAR_NAME_MAX_LEN 16
typedef
struct
{
...
...
src/common/src/texpr.c
浏览文件 @
9aa19d59
...
...
@@ -45,7 +45,10 @@ int32_t exprTreeValidateFunctionNode(tExprNode *pExpr) {
case
TSDB_FUNC_SCALAR_COS
:
case
TSDB_FUNC_SCALAR_SIN
:
case
TSDB_FUNC_SCALAR_TAN
:
case
TSDB_FUNC_SCALAR_SQRT
:{
case
TSDB_FUNC_SCALAR_SQRT
:
case
TSDB_FUNC_SCALAR_CEIL
:
case
TSDB_FUNC_SCALAR_FLOOR
:
case
TSDB_FUNC_SCALAR_ROUND
:
{
return
exprValidateMathNode
(
pExpr
);
}
case
TSDB_FUNC_SCALAR_CONCAT
:
{
...
...
@@ -1002,7 +1005,7 @@ int32_t exprValidateMathNode(tExprNode *pExpr) {
case
TSDB_FUNC_SCALAR_ATAN
:
case
TSDB_FUNC_SCALAR_SIN
:
case
TSDB_FUNC_SCALAR_COS
:
case
TSDB_FUNC_SCALAR_TAN
:{
case
TSDB_FUNC_SCALAR_TAN
:
{
if
(
pExpr
->
_func
.
numChildren
!=
1
)
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
...
...
@@ -1015,6 +1018,20 @@ int32_t exprValidateMathNode(tExprNode *pExpr) {
break
;
}
case
TSDB_FUNC_SCALAR_CEIL
:
case
TSDB_FUNC_SCALAR_FLOOR
:
case
TSDB_FUNC_SCALAR_ROUND
:
{
if
(
pExpr
->
_func
.
numChildren
!=
1
)
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
tExprNode
*
child
=
pExpr
->
_func
.
pChildren
[
0
];
if
(
!
IS_NUMERIC_TYPE
(
child
->
resultType
))
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
pExpr
->
resultType
=
child
->
resultType
;
pExpr
->
resultBytes
=
child
->
resultBytes
;
break
;
}
default:
{
assert
(
false
);
break
;
...
...
@@ -1227,6 +1244,68 @@ void vectorMathFunc(int16_t functionId, tExprOperandInfo *pInputs, uint8_t numIn
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
break
;
}
case
TSDB_FUNC_SCALAR_CEIL
:
{
assert
(
numInputs
==
1
);
assert
(
IS_NUMERIC_TYPE
(
pInputs
[
0
].
type
));
if
(
IS_UNSIGNED_NUMERIC_TYPE
(
pInputs
[
0
].
type
)
||
IS_SIGNED_NUMERIC_TYPE
(
pInputs
[
0
].
type
))
{
memcpy
(
outputData
,
inputData
[
0
],
pInputs
[
0
].
bytes
);
}
else
{
if
(
pInputs
[
0
].
type
==
TSDB_DATA_TYPE_FLOAT
)
{
float
v
=
0
;
GET_TYPED_DATA
(
v
,
float
,
pInputs
[
0
].
type
,
inputData
[
0
]);
float
result
=
ceilf
(
v
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
else
if
(
pInputs
[
0
].
type
==
TSDB_DATA_TYPE_DOUBLE
)
{
double
v
=
0
;
GET_TYPED_DATA
(
v
,
float
,
pInputs
[
0
].
type
,
inputData
[
0
]);
double
result
=
ceil
(
v
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
}
break
;
}
case
TSDB_FUNC_SCALAR_FLOOR
:
{
assert
(
numInputs
==
1
);
assert
(
IS_NUMERIC_TYPE
(
pInputs
[
0
].
type
));
if
(
IS_UNSIGNED_NUMERIC_TYPE
(
pInputs
[
0
].
type
)
||
IS_SIGNED_NUMERIC_TYPE
(
pInputs
[
0
].
type
))
{
memcpy
(
outputData
,
inputData
[
0
],
pInputs
[
0
].
bytes
);
}
else
{
if
(
pInputs
[
0
].
type
==
TSDB_DATA_TYPE_FLOAT
)
{
float
v
=
0
;
GET_TYPED_DATA
(
v
,
float
,
pInputs
[
0
].
type
,
inputData
[
0
]);
float
result
=
floorf
(
v
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
else
if
(
pInputs
[
0
].
type
==
TSDB_DATA_TYPE_DOUBLE
)
{
double
v
=
0
;
GET_TYPED_DATA
(
v
,
float
,
pInputs
[
0
].
type
,
inputData
[
0
]);
double
result
=
floor
(
v
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
}
break
;
}
case
TSDB_FUNC_SCALAR_ROUND
:
{
assert
(
numInputs
==
1
);
assert
(
IS_NUMERIC_TYPE
(
pInputs
[
0
].
type
));
if
(
IS_UNSIGNED_NUMERIC_TYPE
(
pInputs
[
0
].
type
)
||
IS_SIGNED_NUMERIC_TYPE
(
pInputs
[
0
].
type
))
{
memcpy
(
outputData
,
inputData
[
0
],
pInputs
[
0
].
bytes
);
}
else
{
if
(
pInputs
[
0
].
type
==
TSDB_DATA_TYPE_FLOAT
)
{
float
v
=
0
;
GET_TYPED_DATA
(
v
,
float
,
pInputs
[
0
].
type
,
inputData
[
0
]);
float
result
=
roundf
(
v
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
else
if
(
pInputs
[
0
].
type
==
TSDB_DATA_TYPE_DOUBLE
)
{
double
v
=
0
;
GET_TYPED_DATA
(
v
,
float
,
pInputs
[
0
].
type
,
inputData
[
0
]);
double
result
=
round
(
v
);
SET_TYPED_DATA
(
outputData
,
pOutput
->
type
,
result
);
}
}
break
;
}
default:
{
assert
(
false
);
break
;
...
...
@@ -1295,6 +1374,21 @@ tScalarFunctionInfo aScalarFunctions[] = {
"sqrt"
,
vectorMathFunc
,
},
{
TSDB_FUNC_SCALAR_CEIL
,
"ceil"
,
vectorMathFunc
,
},
{
TSDB_FUNC_SCALAR_FLOOR
,
"flooor"
,
vectorMathFunc
,
},
{
TSDB_FUNC_SCALAR_ROUND
,
"round"
,
vectorMathFunc
},
{
TSDB_FUNC_SCALAR_CONCAT
,
"concat"
,
...
...
src/query/src/qAggMain.c
浏览文件 @
9aa19d59
...
...
@@ -469,16 +469,6 @@ int32_t getResultDataInfo(int32_t dataType, int32_t dataBytes, int32_t functionI
// TODO use hash table
int32_t
isValidFunction
(
const
char
*
name
,
int32_t
len
)
{
for
(
int32_t
i
=
0
;
i
<=
TSDB_FUNC_BLKINFO
;
++
i
)
{
int32_t
nameLen
=
(
int32_t
)
strlen
(
aAggs
[
i
].
name
);
if
(
len
!=
nameLen
)
{
continue
;
}
if
(
strncasecmp
(
aAggs
[
i
].
name
,
name
,
len
)
==
0
)
{
return
i
;
}
}
for
(
int32_t
i
=
0
;
i
<
TSDB_FUNC_SCALAR_MAX_NUM
;
++
i
)
{
int32_t
nameLen
=
(
int32_t
)
strlen
(
aScalarFunctions
[
i
].
name
);
...
...
@@ -490,7 +480,17 @@ int32_t isValidFunction(const char* name, int32_t len) {
return
aScalarFunctions
[
i
].
functionId
;
}
}
for
(
int32_t
i
=
0
;
i
<=
TSDB_FUNC_BLKINFO
;
++
i
)
{
int32_t
nameLen
=
(
int32_t
)
strlen
(
aAggs
[
i
].
name
);
if
(
len
!=
nameLen
)
{
continue
;
}
if
(
strncasecmp
(
aAggs
[
i
].
name
,
name
,
len
)
==
0
)
{
return
i
;
}
}
return
-
1
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录