Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
Shardingsphere
提交
2de499aa
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 搜索 >>
提交
2de499aa
编写于
8月 22, 2017
作者:
T
terrymanu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor Having
上级
7c7dc0dc
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
46 addition
and
10 deletion
+46
-10
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/mysql/MySQLSelectParser.java
...rding/parsing/parser/dialect/mysql/MySQLSelectParser.java
+5
-1
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/oracle/OracleSelectParser.java
...ing/parsing/parser/dialect/oracle/OracleSelectParser.java
+5
-1
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/postgresql/PostgreSQLSelectParser.java
...ing/parser/dialect/postgresql/PostgreSQLSelectParser.java
+5
-1
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/sqlserver/SQLServerSelectParser.java
...rsing/parser/dialect/sqlserver/SQLServerSelectParser.java
+5
-1
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/sql/HavingSQLParser.java
...rame/rdb/sharding/parsing/parser/sql/HavingSQLParser.java
+26
-0
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
+0
-6
未找到文件。
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/mysql/MySQLSelectParser.java
浏览文件 @
2de499aa
...
...
@@ -31,6 +31,7 @@ import com.dangdang.ddframe.rdb.sharding.parsing.parser.exception.SQLParsingExce
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.AbstractOrderBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.DistinctSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.GroupBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.HavingSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.SelectListSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.WhereSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.statement.dql.select.AbstractSelectParser
;
...
...
@@ -51,6 +52,8 @@ public final class MySQLSelectParser extends AbstractSelectParser {
private
final
GroupBySQLParser
groupBySQLParser
;
private
final
HavingSQLParser
havingSQLParser
;
private
final
AbstractOrderBySQLParser
orderBySQLParser
;
public
MySQLSelectParser
(
final
ShardingRule
shardingRule
,
final
LexerEngine
lexerEngine
)
{
...
...
@@ -58,6 +61,7 @@ public final class MySQLSelectParser extends AbstractSelectParser {
distinctSQLParser
=
new
MySQLDistinctSQLParser
(
lexerEngine
);
selectListSQLParser
=
new
SelectListSQLParser
(
shardingRule
,
lexerEngine
);
groupBySQLParser
=
new
MySQLGroupBySQLParser
(
lexerEngine
);
havingSQLParser
=
new
HavingSQLParser
(
lexerEngine
);
orderBySQLParser
=
new
MySQLOrderBySQLParser
(
lexerEngine
);
}
...
...
@@ -69,7 +73,7 @@ public final class MySQLSelectParser extends AbstractSelectParser {
parseFrom
(
selectStatement
);
parseWhere
(
selectStatement
);
groupBySQLParser
.
parse
(
selectStatement
);
parseHaving
();
havingSQLParser
.
parse
();
orderBySQLParser
.
parse
(
selectStatement
);
parseLimit
(
selectStatement
);
parseRest
();
...
...
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/oracle/OracleSelectParser.java
浏览文件 @
2de499aa
...
...
@@ -27,6 +27,7 @@ import com.dangdang.ddframe.rdb.sharding.parsing.parser.exception.SQLParsingUnsu
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.AbstractOrderBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.DistinctSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.GroupBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.HavingSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.SelectListSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.statement.dql.select.AbstractSelectParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.statement.dql.select.SelectStatement
;
...
...
@@ -46,6 +47,8 @@ public final class OracleSelectParser extends AbstractSelectParser {
private
final
GroupBySQLParser
groupBySQLParser
;
private
final
HavingSQLParser
havingSQLParser
;
private
final
AbstractOrderBySQLParser
orderBySQLParser
;
public
OracleSelectParser
(
final
ShardingRule
shardingRule
,
final
LexerEngine
lexerEngine
)
{
...
...
@@ -53,6 +56,7 @@ public final class OracleSelectParser extends AbstractSelectParser {
distinctSQLParser
=
new
OracleDistinctSQLParser
(
lexerEngine
);
selectListSQLParser
=
new
OracleSelectListSQLParser
(
shardingRule
,
lexerEngine
);
groupBySQLParser
=
new
OracleGroupBySQLParser
(
lexerEngine
);
havingSQLParser
=
new
HavingSQLParser
(
lexerEngine
);
orderBySQLParser
=
new
OracleOrderBySQLParser
(
lexerEngine
);
}
...
...
@@ -64,7 +68,7 @@ public final class OracleSelectParser extends AbstractSelectParser {
parseWhere
(
selectStatement
);
skipHierarchicalQueryClause
(
selectStatement
);
groupBySQLParser
.
parse
(
selectStatement
);
parseHaving
();
havingSQLParser
.
parse
();
skipModelClause
(
selectStatement
);
orderBySQLParser
.
parse
(
selectStatement
);
skipFor
(
selectStatement
);
...
...
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/postgresql/PostgreSQLSelectParser.java
浏览文件 @
2de499aa
...
...
@@ -31,6 +31,7 @@ import com.dangdang.ddframe.rdb.sharding.parsing.parser.exception.SQLParsingUnsu
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.AbstractOrderBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.DistinctSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.GroupBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.HavingSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.SelectListSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.WhereSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.statement.dql.select.AbstractSelectParser
;
...
...
@@ -53,6 +54,8 @@ public final class PostgreSQLSelectParser extends AbstractSelectParser {
private
final
GroupBySQLParser
groupBySQLParser
;
private
final
HavingSQLParser
havingSQLParser
;
private
final
AbstractOrderBySQLParser
orderBySQLParser
;
public
PostgreSQLSelectParser
(
final
ShardingRule
shardingRule
,
final
LexerEngine
lexerEngine
)
{
...
...
@@ -60,6 +63,7 @@ public final class PostgreSQLSelectParser extends AbstractSelectParser {
distinctSQLParser
=
new
DistinctSQLParser
(
lexerEngine
);
selectListSQLParser
=
new
SelectListSQLParser
(
shardingRule
,
lexerEngine
);
groupBySQLParser
=
new
GroupBySQLParser
(
lexerEngine
);
havingSQLParser
=
new
HavingSQLParser
(
lexerEngine
);
orderBySQLParser
=
new
PostgreSQLOrderBySQLParser
(
lexerEngine
);
}
...
...
@@ -70,7 +74,7 @@ public final class PostgreSQLSelectParser extends AbstractSelectParser {
parseFrom
(
selectStatement
);
parseWhere
(
selectStatement
);
groupBySQLParser
.
parse
(
selectStatement
);
parseHaving
();
havingSQLParser
.
parse
();
orderBySQLParser
.
parse
(
selectStatement
);
parseLimit
(
selectStatement
);
parseFor
();
...
...
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/dialect/sqlserver/SQLServerSelectParser.java
浏览文件 @
2de499aa
...
...
@@ -34,6 +34,7 @@ import com.dangdang.ddframe.rdb.sharding.parsing.parser.expression.SQLPlaceholde
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.AbstractOrderBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.DistinctSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.GroupBySQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.HavingSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql.SelectListSQLParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.statement.dql.select.AbstractSelectParser
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.statement.dql.select.SelectStatement
;
...
...
@@ -52,6 +53,8 @@ public final class SQLServerSelectParser extends AbstractSelectParser {
private
final
GroupBySQLParser
groupBySQLParser
;
private
final
HavingSQLParser
havingSQLParser
;
private
final
AbstractOrderBySQLParser
orderBySQLParser
;
public
SQLServerSelectParser
(
final
ShardingRule
shardingRule
,
final
LexerEngine
lexerEngine
)
{
...
...
@@ -59,6 +62,7 @@ public final class SQLServerSelectParser extends AbstractSelectParser {
distinctSQLParser
=
new
DistinctSQLParser
(
lexerEngine
);
selectListSQLParser
=
new
SQLServerSelectListSQLParser
(
shardingRule
,
lexerEngine
);
groupBySQLParser
=
new
GroupBySQLParser
(
lexerEngine
);
havingSQLParser
=
new
HavingSQLParser
(
lexerEngine
);
orderBySQLParser
=
new
MySQLOrderBySQLParser
(
lexerEngine
);
}
...
...
@@ -70,7 +74,7 @@ public final class SQLServerSelectParser extends AbstractSelectParser {
parseFrom
(
selectStatement
);
parseWhere
(
selectStatement
);
groupBySQLParser
.
parse
(
selectStatement
);
parseHaving
();
havingSQLParser
.
parse
();
orderBySQLParser
.
parse
(
selectStatement
);
parseOffset
(
selectStatement
);
parseFor
();
...
...
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/sql/HavingSQLParser.java
0 → 100644
浏览文件 @
2de499aa
package
com.dangdang.ddframe.rdb.sharding.parsing.parser.sql
;
import
com.dangdang.ddframe.rdb.sharding.parsing.lexer.LexerEngine
;
import
com.dangdang.ddframe.rdb.sharding.parsing.lexer.token.DefaultKeyword
;
import
com.dangdang.ddframe.rdb.sharding.parsing.parser.exception.SQLParsingUnsupportedException
;
import
lombok.RequiredArgsConstructor
;
/**
* Having解析器.
*
* @author zhangliang
*/
@RequiredArgsConstructor
public
final
class
HavingSQLParser
implements
SQLParser
{
private
final
LexerEngine
lexerEngine
;
/**
* 解析Having.
*/
public
void
parse
()
{
if
(
lexerEngine
.
equalAny
(
DefaultKeyword
.
HAVING
))
{
throw
new
SQLParsingUnsupportedException
(
DefaultKeyword
.
HAVING
);
}
}
}
sharding-jdbc-core/src/main/java/com/dangdang/ddframe/rdb/sharding/parsing/parser/statement/dql/select/AbstractSelectParser.java
浏览文件 @
2de499aa
...
...
@@ -174,12 +174,6 @@ public abstract class AbstractSelectParser implements SQLStatementParser {
parametersIndex
=
selectStatement
.
getParametersIndex
();
}
protected
final
void
parseHaving
()
{
if
(
lexerEngine
.
equalAny
(
DefaultKeyword
.
HAVING
))
{
throw
new
SQLParsingUnsupportedException
(
DefaultKeyword
.
HAVING
);
}
}
protected
final
void
parseRest
()
{
Collection
<
Keyword
>
unsupportedRestKeywords
=
new
LinkedList
<>();
unsupportedRestKeywords
.
addAll
(
Arrays
.
asList
(
DefaultKeyword
.
UNION
,
DefaultKeyword
.
INTERSECT
,
DefaultKeyword
.
EXCEPT
,
DefaultKeyword
.
MINUS
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录