Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
69b3dd59
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,体验更适合开发者的 AI 搜索 >>
提交
69b3dd59
编写于
8月 11, 2017
作者:
T
terrymanu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor parseSelectList 10th version
上级
8097d7ce
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
32 addition
and
3 deletion
+32
-3
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/statement/dql/select/AbstractSelectParser.java
...ing/parser/statement/dql/select/AbstractSelectParser.java
+2
-2
sharding-jdbc-core/src/test/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/base/AbstractBaseParseSQLTest.java
...harding/parsing/parser/base/AbstractBaseParseSQLTest.java
+0
-1
sharding-jdbc-core/src/test/resources/parser/select_pagination.xml
...jdbc-core/src/test/resources/parser/select_pagination.xml
+6
-0
sharding-jdbc-core/src/test/resources/parser/select_pagination_group_by_order_by.xml
.../resources/parser/select_pagination_group_by_order_by.xml
+24
-0
未找到文件。
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/statement/dql/select/AbstractSelectParser.java
浏览文件 @
69b3dd59
...
...
@@ -349,7 +349,7 @@ public abstract class AbstractSelectParser implements SQLStatementParser {
sqlParser
.
skipUselessParentheses
();
parse
();
sqlParser
.
skipUselessParentheses
();
if
(
!
selectStatement
.
getTables
().
isEmpty
()
||
getSqlParser
().
equalAny
(
DefaultKeyword
.
WHERE
,
Assist
.
END
))
{
if
(
getSqlParser
().
equalAny
(
DefaultKeyword
.
WHERE
,
Assist
.
END
))
{
return
;
}
}
...
...
@@ -362,8 +362,8 @@ public abstract class AbstractSelectParser implements SQLStatementParser {
}
protected
final
void
parseTableFactor
()
{
final
int
beginPosition
=
sqlParser
.
getLexer
().
getCurrentToken
().
getEndPosition
()
-
sqlParser
.
getLexer
().
getCurrentToken
().
getLiterals
().
length
();
sqlParser
.
skipAll
(
DefaultKeyword
.
AS
);
final
int
beginPosition
=
sqlParser
.
getLexer
().
getCurrentToken
().
getEndPosition
()
-
sqlParser
.
getLexer
().
getCurrentToken
().
getLiterals
().
length
();
String
literals
=
sqlParser
.
getLexer
().
getCurrentToken
().
getLiterals
();
sqlParser
.
getLexer
().
nextToken
();
// TODO 包含Schema解析
...
...
sharding-jdbc-core/src/test/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/base/AbstractBaseParseSQLTest.java
浏览文件 @
69b3dd59
...
...
@@ -53,7 +53,6 @@ public abstract class AbstractBaseParseSQLTest extends AbstractBaseParseTest {
}
}
private
void
assertExpectedTables
(
final
SQLStatement
actual
)
{
assertTrue
(
new
ReflectionEquals
(
getExpectedTables
()).
matches
(
actual
.
getTables
()));
}
...
...
sharding-jdbc-core/src/test/resources/parser/select_pagination.xml
浏览文件 @
69b3dd59
...
...
@@ -138,6 +138,9 @@
<value
index=
"3"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<order-by-columns>
<order-by-column
name=
"item_id"
alias=
"ORDER_BY_DERIVED_0"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
<limit
row-count=
"3"
row-count-index=
"4"
/>
</assert>
<assert
id=
"assertSelectPaginationWithOffsetAndRowCountInOracle"
parameters=
"1,2,9,10,5,3"
>
...
...
@@ -157,6 +160,9 @@
<value
index=
"3"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<order-by-columns>
<order-by-column
name=
"item_id"
alias=
"ORDER_BY_DERIVED_0"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
<limit
offset=
"3"
offset-index=
"5"
row-count-index=
"4"
row-count=
"5"
/>
</assert>
</asserts>
sharding-jdbc-core/src/test/resources/parser/select_pagination_group_by_order_by.xml
浏览文件 @
69b3dd59
...
...
@@ -62,6 +62,9 @@
<value
index=
"4"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<group-by-columns>
<group-by-column
name=
"item_id"
owner=
"i"
order-by-type=
"ASC"
/>
</group-by-columns>
<order-by-columns>
<order-by-column
name=
"item_id"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
...
...
@@ -83,6 +86,9 @@
<value
index=
"4"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<group-by-columns>
<group-by-column
name=
"user_id"
alias=
"GROUP_BY_DERIVED_0"
owner=
"i"
order-by-type=
"ASC"
/>
</group-by-columns>
<order-by-columns>
<order-by-column
name=
"item_id"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
...
...
@@ -104,6 +110,9 @@
<value
index=
"4"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<group-by-columns>
<group-by-column
name=
"item_id"
owner=
"i"
order-by-type=
"ASC"
/>
</group-by-columns>
<order-by-columns>
<order-by-column
name=
"item_id"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
...
...
@@ -125,6 +134,9 @@
<value
index=
"4"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<group-by-columns>
<group-by-column
name=
"user_id"
alias=
"GROUP_BY_DERIVED_0"
owner=
"i"
order-by-type=
"ASC"
/>
</group-by-columns>
<order-by-columns>
<order-by-column
name=
"item_id"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
...
...
@@ -147,6 +159,12 @@
<value
index=
"3"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<group-by-columns>
<group-by-column
name=
"item_id"
alias=
"GROUP_BY_DERIVED_0"
owner=
"i"
order-by-type=
"ASC"
/>
</group-by-columns>
<order-by-columns>
<order-by-column
name=
"item_id"
alias=
"ORDER_BY_DERIVED_0"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
<limit
offset=
"3"
offset-index=
"5"
row-count-index=
"4"
row-count=
"5"
/>
</assert>
<assert
id=
"assertSelectPaginationWithDiffGroupByAndOrderByInOracle"
parameters=
"1,2,9,10,5,3"
>
...
...
@@ -166,6 +184,12 @@
<value
index=
"3"
literal=
"10"
type=
"int"
/>
</condition>
</conditions>
<group-by-columns>
<group-by-column
name=
"user_id"
alias=
"GROUP_BY_DERIVED_0"
owner=
"i"
order-by-type=
"ASC"
/>
</group-by-columns>
<order-by-columns>
<order-by-column
name=
"item_id"
alias=
"ORDER_BY_DERIVED_0"
owner=
"i"
order-by-type=
"DESC"
/>
</order-by-columns>
<limit
offset=
"3"
offset-index=
"5"
row-count-index=
"4"
row-count=
"5"
/>
</assert>
</asserts>
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录