Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
81c3507b
Shardingsphere
项目概览
apache
/
Shardingsphere
通知
56
Star
3
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Shardingsphere
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
81c3507b
编写于
6月 05, 2019
作者:
T
tristaZero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
to AppendOrderByItems or not
上级
27c86b1a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
6 addition
and
2 deletion
+6
-2
sharding-core/sharding-core-parse/sharding-core-parse-common/src/main/java/org/apache/shardingsphere/core/parse/optimizer/select/SelectOptimizer.java
...ngsphere/core/parse/optimizer/select/SelectOptimizer.java
+2
-0
sharding-core/sharding-core-parse/sharding-core-parse-common/src/main/java/org/apache/shardingsphere/core/parse/sql/statement/dml/SelectStatement.java
...gsphere/core/parse/sql/statement/dml/SelectStatement.java
+3
-1
sharding-core/sharding-core-rewrite/src/main/java/org/apache/shardingsphere/core/rewrite/token/generator/OrderByTokenGenerator.java
...e/core/rewrite/token/generator/OrderByTokenGenerator.java
+1
-1
未找到文件。
sharding-core/sharding-core-parse/sharding-core-parse-common/src/main/java/org/apache/shardingsphere/core/parse/optimizer/select/SelectOptimizer.java
浏览文件 @
81c3507b
...
...
@@ -49,6 +49,7 @@ public final class SelectOptimizer implements SQLStatementOptimizer {
@Override
public
void
optimize
(
final
SQLStatement
sqlStatement
,
final
ShardingTableMetaData
shardingTableMetaData
)
{
appendDerivedColumns
((
SelectStatement
)
sqlStatement
,
shardingTableMetaData
);
appendDerivedOrderBy
((
SelectStatement
)
sqlStatement
);
addSubqueryCondition
(
sqlStatement
);
...
...
@@ -170,6 +171,7 @@ public final class SelectOptimizer implements SQLStatementOptimizer {
private
void
appendDerivedOrderBy
(
final
SelectStatement
selectStatement
)
{
if
(!
selectStatement
.
getGroupByItems
().
isEmpty
()
&&
selectStatement
.
getOrderByItems
().
isEmpty
())
{
selectStatement
.
getOrderByItems
().
addAll
(
selectStatement
.
getGroupByItems
());
selectStatement
.
setToAppendOrderByItems
(
true
);
}
}
...
...
sharding-core/sharding-core-parse/sharding-core-parse-common/src/main/java/org/apache/shardingsphere/core/parse/sql/statement/dml/SelectStatement.java
浏览文件 @
81c3507b
...
...
@@ -61,6 +61,8 @@ public final class SelectStatement extends DQLStatement {
private
final
List
<
OrderByItemSegment
>
orderByItems
=
new
LinkedList
<>();
private
boolean
toAppendOrderByItems
;
private
boolean
containStar
;
private
int
firstSelectItemStartIndex
;
...
...
@@ -69,7 +71,7 @@ public final class SelectStatement extends DQLStatement {
private
int
groupByLastIndex
;
private
LimitSegment
limit
;
private
LimitSegment
limit
;
private
SelectStatement
parentStatement
;
...
...
sharding-core/sharding-core-rewrite/src/main/java/org/apache/shardingsphere/core/rewrite/token/generator/OrderByTokenGenerator.java
浏览文件 @
81c3507b
...
...
@@ -35,7 +35,7 @@ public final class OrderByTokenGenerator implements OptionalSQLTokenGenerator<Sh
if
(!(
sqlStatement
instanceof
SelectStatement
))
{
return
Optional
.
absent
();
}
if
(
!((
SelectStatement
)
sqlStatement
).
getGroupByItems
().
isEmpty
()
&&
((
SelectStatement
)
sqlStatement
).
getOrderByItems
().
isEmpty
())
{
if
(
((
SelectStatement
)
sqlStatement
).
isToAppendOrderByItems
())
{
return
Optional
.
of
(
new
OrderByToken
(((
SelectStatement
)
sqlStatement
).
getGroupByLastIndex
()
+
1
));
}
return
Optional
.
absent
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录