Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
0819d264
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看板
提交
0819d264
编写于
1月 22, 2022
作者:
S
shenglian zhou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
(query):string functions: case, trim
上级
78445fdf
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
113 addition
and
2 deletion
+113
-2
src/common/src/texpr.c
src/common/src/texpr.c
+113
-2
未找到文件。
src/common/src/texpr.c
浏览文件 @
0819d264
...
...
@@ -1076,7 +1076,7 @@ int32_t exprValidateStringLowerUpperTrimNode(char* msgBuf, tExprNode *pExpr) {
}
int32_t
exprValidateStringSubstrNode
(
char
*
msgBuf
,
tExprNode
*
pExpr
)
{
if
(
pExpr
->
_func
.
numChildren
!=
2
||
pExpr
->
_func
.
numChildren
!=
3
)
{
if
(
(
pExpr
->
_func
.
numChildren
!=
2
)
&&
(
pExpr
->
_func
.
numChildren
!=
3
)
)
{
return
TSDB_CODE_TSC_INVALID_OPERATION
;
}
...
...
@@ -1475,7 +1475,118 @@ void vectorCharLength(int16_t functionId, tExprOperandInfo *pInputs, int32_t num
void
vectorLowerUpperTrimFunc
(
int16_t
functionId
,
tExprOperandInfo
*
pInputs
,
int32_t
numInputs
,
tExprOperandInfo
*
pOutput
,
int32_t
order
)
{
assert
(
numInputs
==
1
);
assert
(
pInputs
[
0
].
numOfRows
==
1
||
pInputs
[
0
].
numOfRows
==
pOutput
->
numOfRows
);
char
*
outputData
=
NULL
;
char
**
inputData
=
calloc
(
numInputs
,
sizeof
(
char
*
));
int16_t
inputType
=
pInputs
[
0
].
type
;
for
(
int
i
=
0
;
i
<
pOutput
->
numOfRows
;
++
i
)
{
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
)
{
switch
(
functionId
)
{
case
TSDB_FUNC_SCALAR_LOWER
:
case
TSDB_FUNC_SCALAR_UPPER
:
{
assert
(
numInputs
=
1
);
int32_t
len
=
varDataLen
(
inputData
[
0
]);
varDataSetLen
(
outputData
,
len
);
if
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
{
char
*
pInputChar
=
varDataVal
(
inputData
[
0
]);
char
*
pOutputChar
=
varDataVal
(
outputData
);
for
(
int32_t
k
=
0
;
k
<
len
;
++
k
)
{
if
(
functionId
==
TSDB_FUNC_SCALAR_LOWER
)
*
(
pOutputChar
+
k
)
=
tolower
(
*
(
pInputChar
+
k
));
else
*
(
pOutputChar
+
k
)
=
toupper
(
*
(
pInputChar
+
k
));
}
}
else
if
(
inputType
==
TSDB_DATA_TYPE_NCHAR
)
{
uint32_t
*
pInputChar
=
(
uint32_t
*
)
varDataVal
(
inputData
[
0
]);
uint32_t
*
pOutputChar
=
(
uint32_t
*
)
varDataVal
(
outputData
);
for
(
int32_t
k
=
0
;
k
<
len
/
TSDB_NCHAR_SIZE
;
++
k
)
{
if
(
functionId
==
TSDB_FUNC_SCALAR_LOWER
)
*
(
pOutputChar
+
k
)
=
towlower
(
*
(
pInputChar
+
k
));
else
*
(
pOutputChar
+
k
)
=
towupper
((
*
(
pInputChar
+
k
)));
}
}
break
;
}
case
TSDB_FUNC_SCALAR_LTRIM
:
{
int32_t
len
=
varDataLen
(
inputData
[
0
]);
int32_t
charLen
=
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
?
len
:
len
/
TSDB_NCHAR_SIZE
;
int32_t
k
=
0
;
for
(;
k
<
charLen
;
++
k
)
{
if
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
{
char
*
pInputChar
=
(
char
*
)
varDataVal
(
inputData
[
0
]);
if
(
!
isspace
(
*
(
pInputChar
+
k
)))
{
break
;
}
}
else
{
uint32_t
*
pInputChar
=
(
uint32_t
*
)
varDataVal
(
inputData
[
0
]);
if
(
!
iswspace
(
*
(
pInputChar
+
k
)))
{
break
;
}
}
}
int32_t
resultCharLen
=
charLen
-
k
;
int32_t
resultByteLen
=
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
?
resultCharLen
:
resultCharLen
*
TSDB_NCHAR_SIZE
;
int32_t
beginByteLen
=
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
?
k
:
k
*
TSDB_NCHAR_SIZE
;
varDataSetLen
(
outputData
,
resultByteLen
);
memcpy
(
varDataVal
(
outputData
),
varDataVal
(
inputData
[
0
])
+
beginByteLen
,
resultByteLen
);
break
;
}
case
TSDB_FUNC_SCALAR_RTRIM
:
{
int32_t
len
=
varDataLen
(
inputData
[
0
]);
int32_t
charLen
=
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
?
len
:
len
/
TSDB_NCHAR_SIZE
;
int32_t
k
=
charLen
-
1
;
for
(;
k
>=
0
;
--
k
)
{
if
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
{
char
*
pInputChar
=
(
char
*
)
varDataVal
(
inputData
[
0
]);
if
(
!
isspace
(
*
(
pInputChar
+
k
)))
{
break
;
}
}
else
{
uint32_t
*
pInputChar
=
(
uint32_t
*
)
varDataVal
(
inputData
[
0
]);
if
(
!
iswspace
(
*
(
pInputChar
+
k
)))
{
break
;
}
}
}
int32_t
resultCharLen
=
k
+
1
;
int32_t
resultByteLen
=
(
inputType
==
TSDB_DATA_TYPE_BINARY
)
?
resultCharLen
:
resultCharLen
*
TSDB_NCHAR_SIZE
;
varDataSetLen
(
outputData
,
resultByteLen
);
memcpy
(
varDataVal
(
outputData
),
varDataVal
(
inputData
[
0
]),
resultByteLen
);
break
;
}
case
TSDB_FUNC_SCALAR_SUBSTR
:
{
break
;
}
}
}
}
free
(
inputData
);
}
void
vectorSubstrFunc
(
int16_t
functionId
,
tExprOperandInfo
*
pInputs
,
int32_t
numInputs
,
tExprOperandInfo
*
pOutput
,
int32_t
order
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录