Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Metz
oceanbase
提交
ab74cf74
O
oceanbase
项目概览
Metz
/
oceanbase
与 Fork 源项目一致
Fork自
oceanbase / oceanbase
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oceanbase
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ab74cf74
编写于
3月 04, 2022
作者:
Q
qianchanger
提交者:
LINGuanRen
3月 04, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix window function parallel bug
上级
f0d7d9d6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
17 addition
and
6 deletion
+17
-6
src/sql/engine/aggregate/ob_aggregate_processor.cpp
src/sql/engine/aggregate/ob_aggregate_processor.cpp
+10
-5
src/sql/engine/window_function/ob_window_function_op.cpp
src/sql/engine/window_function/ob_window_function_op.cpp
+7
-1
未找到文件。
src/sql/engine/aggregate/ob_aggregate_processor.cpp
浏览文件 @
ab74cf74
...
...
@@ -3122,11 +3122,16 @@ int ObAggregateCalcFunc::add_calc(const ObDatum& left_value, const ObDatum& righ
break
;
}
case
ObNumberTC
:
{
if
(
left_value
.
is_null
()
&&
OB_FAIL
(
clone_number_cell
(
right_value
.
get_number
(),
result_datum
,
out_allocator
)))
{
LOG_WARN
(
"fail to clone number cell"
,
K
(
ret
));
}
else
if
(
right_value
.
is_null
()
&&
OB_FAIL
(
clone_number_cell
(
left_value
.
get_number
(),
result_datum
,
out_allocator
)))
{
LOG_WARN
(
"fail to clone number cell"
,
K
(
ret
));
if
(
left_value
.
is_null
())
{
if
(
OB_FAIL
(
clone_number_cell
(
right_value
.
get_number
(),
result_datum
,
out_allocator
)))
{
LOG_WARN
(
"fail to clone number cell"
,
K
(
ret
));
}
}
else
if
(
right_value
.
is_null
())
{
if
(
OB_FAIL
(
clone_number_cell
(
left_value
.
get_number
(),
result_datum
,
out_allocator
)))
{
LOG_WARN
(
"fail to clone number cell"
,
K
(
ret
));
}
}
else
{
char
buf_alloc
[
ObNumber
::
MAX_CALC_BYTE_LEN
];
ObDataBuffer
allocator
(
buf_alloc
,
ObNumber
::
MAX_CALC_BYTE_LEN
);
...
...
src/sql/engine/window_function/ob_window_function_op.cpp
浏览文件 @
ab74cf74
...
...
@@ -1364,7 +1364,12 @@ int ObWindowFunctionOp::parallel_winbuf_process()
ObDatum
&
l_datum
=
new_row
->
cells
()[
idx
];
const
ObDatum
&
r_datum
=
row
->
cells
()[
idx
];
ObDatumCmpFuncType
cmp_func
=
cmp_funcs
.
at
(
cmp_index
);
if
(
cmp_func
(
l_datum
,
r_datum
)
<
0
)
{
// null-last cmp func should ignore null in max calc
if
(
r_datum
.
is_null
()
&&
!
l_datum
.
is_null
())
{
/*do nothing*/
}
else
if
(
!
r_datum
.
is_null
()
&&
l_datum
.
is_null
())
{
l_datum
=
r_datum
;
}
else
if
(
cmp_func
(
l_datum
,
r_datum
)
<
0
)
{
l_datum
=
r_datum
;
}
cmp_index
++
;
...
...
@@ -1374,6 +1379,7 @@ int ObWindowFunctionOp::parallel_winbuf_process()
ObDatum
&
l_datum
=
new_row
->
cells
()[
idx
];
const
ObDatum
&
r_datum
=
row
->
cells
()[
idx
];
ObDatumCmpFuncType
cmp_func
=
cmp_funcs
.
at
(
cmp_index
);
// null-last cmp func no need null special calc in min calc
if
(
cmp_func
(
l_datum
,
r_datum
)
>
0
)
{
l_datum
=
r_datum
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录