Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Metz
oceanbase
提交
d63d51a1
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看板
提交
d63d51a1
编写于
5月 16, 2022
作者:
O
obdev
提交者:
wangzelin.wzl
5月 16, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[CP] fix win magic bug
上级
1f5c1bfd
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
49 addition
and
2 deletion
+49
-2
src/sql/rewrite/ob_transform_win_magic.cpp
src/sql/rewrite/ob_transform_win_magic.cpp
+44
-1
src/sql/rewrite/ob_transform_win_magic.h
src/sql/rewrite/ob_transform_win_magic.h
+5
-1
未找到文件。
src/sql/rewrite/ob_transform_win_magic.cpp
浏览文件 @
d63d51a1
...
@@ -167,6 +167,16 @@ int ObTransformWinMagic::check_subquery_validity(
...
@@ -167,6 +167,16 @@ int ObTransformWinMagic::check_subquery_validity(
LOG_WARN
(
"invalid condition map size"
,
K
(
ret
),
K
(
map_info
.
cond_map_
.
count
()),
K
(
subquery
->
get_condition_size
()));
LOG_WARN
(
"invalid condition map size"
,
K
(
ret
),
K
(
map_info
.
cond_map_
.
count
()),
K
(
subquery
->
get_condition_size
()));
}
else
if
(
OB_FAIL
(
context
.
init
(
subquery
,
stmt
,
map_info
.
table_map_
)))
{
}
else
if
(
OB_FAIL
(
context
.
init
(
subquery
,
stmt
,
map_info
.
table_map_
)))
{
LOG_WARN
(
"failed to init stmt compare context"
,
K
(
ret
));
LOG_WARN
(
"failed to init stmt compare context"
,
K
(
ret
));
}
else
{
bool
where_subquery
=
false
;
if
(
OB_FAIL
(
check_is_where_subquery
(
*
stmt
,
query_ref
,
where_subquery
)))
{
LOG_WARN
(
"check is where subquery failed"
,
K
(
ret
));
}
else
if
(
where_subquery
||
!
stmt
->
is_select_stmt
())
{
// do nothing
}
else
if
(
static_cast
<
ObSelectStmt
*>
(
stmt
)
->
is_scala_group_by
())
{
is_valid
=
false
;
}
else
{
}
}
}
/**
/**
* all correlated condition must be equal condition
* all correlated condition must be equal condition
...
@@ -229,7 +239,40 @@ int ObTransformWinMagic::check_subquery_validity(
...
@@ -229,7 +239,40 @@ int ObTransformWinMagic::check_subquery_validity(
return
ret
;
return
ret
;
}
}
int
ObTransformWinMagic
::
check_aggr_expr_validity
(
ObSelectStmt
&
subquery
,
bool
&
is_valid
)
int
ObTransformWinMagic
::
check_contain_expr
(
ObRawExpr
*
base
,
ObRawExpr
*
target
,
bool
&
has
)
{
int
ret
=
OB_SUCCESS
;
if
(
OB_ISNULL
(
base
)
||
OB_ISNULL
(
target
))
{
ret
=
OB_ERR_UNEXPECTED
;
LOG_WARN
(
"raw expr is null"
,
K
(
ret
));
}
else
if
(
base
==
target
)
{
has
=
true
;
}
for
(
int64_t
j
=
0
;
OB_SUCC
(
ret
)
&&
!
has
&&
j
<
base
->
get_param_count
();
j
++
)
{
if
(
OB_FAIL
(
check_contain_expr
(
base
->
get_param_expr
(
j
),
target
,
has
)))
{
LOG_WARN
(
"contain expr failed"
,
K
(
ret
));
}
}
return
ret
;
}
int
ObTransformWinMagic
::
check_is_where_subquery
(
ObDMLStmt
&
stmt
,
ObQueryRefRawExpr
*
query_ref
,
bool
&
is_valid
)
{
int
ret
=
OB_SUCCESS
;
is_valid
=
false
;
for
(
int64_t
i
=
0
;
OB_SUCC
(
ret
)
&&
!
is_valid
&&
i
<
stmt
.
get_condition_size
();
i
++
)
{
ObRawExpr
*
cond
=
stmt
.
get_condition_expr
(
i
);
if
(
OB_ISNULL
(
cond
))
{
ret
=
OB_ERR_UNEXPECTED
;
LOG_WARN
(
"cond is null"
,
K
(
ret
));
}
else
if
(
OB_FAIL
(
check_contain_expr
(
cond
,
query_ref
,
is_valid
)))
{
LOG_WARN
(
"check_contain_expr failed"
,
K
(
ret
));
}
}
return
ret
;
}
int
ObTransformWinMagic
::
check_aggr_expr_validity
(
ObSelectStmt
&
subquery
,
bool
&
is_valid
)
{
{
int
ret
=
OB_SUCCESS
;
int
ret
=
OB_SUCCESS
;
is_valid
=
true
;
is_valid
=
true
;
...
...
src/sql/rewrite/ob_transform_win_magic.h
浏览文件 @
d63d51a1
...
@@ -63,7 +63,11 @@ private:
...
@@ -63,7 +63,11 @@ private:
int
is_simple_from_item
(
ObDMLStmt
&
stmt
,
uint64_t
table_id
,
int64_t
&
from_index
);
int
is_simple_from_item
(
ObDMLStmt
&
stmt
,
uint64_t
table_id
,
int64_t
&
from_index
);
int
use_given_tables
(
const
ObRawExpr
*
expr
,
const
ObIArray
<
uint64_t
>&
table_ids
,
bool
&
is_valid
);
int
use_given_tables
(
const
ObRawExpr
*
expr
,
const
ObIArray
<
uint64_t
>
&
table_ids
,
bool
&
is_valid
);
int
check_is_where_subquery
(
ObDMLStmt
&
stmt
,
ObQueryRefRawExpr
*
query_ref
,
bool
&
is_valid
);
int
check_contain_expr
(
ObRawExpr
*
base
,
ObRawExpr
*
target
,
bool
&
has
);
};
};
}
// namespace sql
}
// namespace sql
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录