Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
大炮V587
oceanbase
提交
4f65ea33
O
oceanbase
项目概览
大炮V587
/
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,发现更多精彩内容 >>
提交
4f65ea33
编写于
2月 06, 2023
作者:
O
obdev
提交者:
ob-robot
2月 06, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Partition sort check earlier and more strictly
上级
0866a4b8
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
14 addition
and
5 deletion
+14
-5
src/sql/code_generator/ob_static_engine_cg.cpp
src/sql/code_generator/ob_static_engine_cg.cpp
+10
-0
src/sql/engine/sort/ob_sort_op_impl.cpp
src/sql/engine/sort/ob_sort_op_impl.cpp
+4
-5
未找到文件。
src/sql/code_generator/ob_static_engine_cg.cpp
浏览文件 @
4f65ea33
...
@@ -1762,6 +1762,16 @@ int ObStaticEngineCG::generate_spec(ObLogSort &op, ObSortSpec &spec, const bool
...
@@ -1762,6 +1762,16 @@ int ObStaticEngineCG::generate_spec(ObLogSort &op, ObSortSpec &spec, const bool
spec
.
part_cnt_
=
op
.
get_part_cnt
();
spec
.
part_cnt_
=
op
.
get_part_cnt
();
LOG_TRACE
(
"trace order by"
,
K
(
spec
.
all_exprs_
.
count
()),
K
(
spec
.
all_exprs_
));
LOG_TRACE
(
"trace order by"
,
K
(
spec
.
all_exprs_
.
count
()),
K
(
spec
.
all_exprs_
));
}
}
if
(
OB_SUCC
(
ret
))
{
if
(
spec
.
sort_collations_
.
count
()
!=
spec
.
sort_cmp_funs_
.
count
()
||
(
spec
.
part_cnt_
>
0
&&
spec
.
part_cnt_
>=
spec
.
sort_collations_
.
count
()))
{
ret
=
OB_INVALID_ARGUMENT
;
LOG_WARN
(
"part cnt or sort size not meet the expection"
,
K
(
ret
),
K
(
OB_NOT_NULL
(
op
.
get_topn_expr
())),
K
(
OB_NOT_NULL
(
op
.
get_topk_limit_expr
())),
K
(
spec
.
enable_encode_sortkey_opt_
),
K
(
spec
.
prefix_pos_
),
K
(
spec
.
is_local_merge_sort_
),
K
(
spec
.
part_cnt_
),
K
(
spec
.
sort_collations_
.
count
()),
K
(
spec
.
sort_cmp_funs_
.
count
()));
}
}
}
}
}
}
return
ret
;
return
ret
;
...
...
src/sql/engine/sort/ob_sort_op_impl.cpp
浏览文件 @
4f65ea33
...
@@ -596,12 +596,11 @@ int ObSortOpImpl::init(
...
@@ -596,12 +596,11 @@ int ObSortOpImpl::init(
}
else
if
(
OB_INVALID_ID
==
tenant_id
)
{
}
else
if
(
OB_INVALID_ID
==
tenant_id
)
{
ret
=
OB_INVALID_ARGUMENT
;
ret
=
OB_INVALID_ARGUMENT
;
LOG_WARN
(
"invalid argument"
,
K
(
ret
),
K
(
tenant_id
));
LOG_WARN
(
"invalid argument"
,
K
(
ret
),
K
(
tenant_id
));
}
else
if
(
OB_ISNULL
(
sort_collations
)
||
OB_ISNULL
(
sort_cmp_funs
)
||
OB_ISNULL
(
eval_ctx
)
}
else
if
(
OB_ISNULL
(
sort_collations
)
||
OB_ISNULL
(
sort_cmp_funs
)
||
sort_collations
->
count
()
!=
sort_cmp_funs
->
count
()
||
OB_ISNULL
(
exec_ctx
)
||
OB_ISNULL
(
eval_ctx
)
||
OB_ISNULL
(
exec_ctx
))
{
||
part_cnt
>
sort_collations
->
count
())
{
ret
=
OB_INVALID_ARGUMENT
;
ret
=
OB_INVALID_ARGUMENT
;
LOG_WARN
(
"invalid argument: argument is null"
,
K
(
ret
),
K
(
tenant_id
),
LOG_WARN
(
"invalid argument: argument is null"
,
K
(
ret
),
K
(
sort_collations
),
K
(
sort_cmp_funs
),
K
(
eval_ctx
),
K
(
part_cnt
));
K
(
tenant_id
),
K
(
sort_collations
),
K
(
sort_cmp_funs
),
K
(
eval_ctx
));
}
else
if
(
OB_FAIL
(
comp_
.
init
(
sort_collations
,
sort_cmp_funs
,
}
else
if
(
OB_FAIL
(
comp_
.
init
(
sort_collations
,
sort_cmp_funs
,
exec_ctx
,
enable_encode_sortkey
)))
{
exec_ctx
,
enable_encode_sortkey
)))
{
LOG_WARN
(
"failed to init compare functions"
,
K
(
ret
));
LOG_WARN
(
"failed to init compare functions"
,
K
(
ret
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录