ElasticSql2DslParser.java 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package org.elasticsearch.dsl.parser;
  2. import com.alibaba.druid.sql.ast.SQLExpr;
  3. import com.alibaba.druid.sql.ast.expr.SQLQueryExpr;
  4. import com.alibaba.druid.sql.parser.ParserException;
  5. import com.alibaba.druid.sql.parser.Token;
  6. import com.google.common.collect.ImmutableList;
  7. import org.elasticsearch.dsl.bean.ElasticDslContext;
  8. import org.elasticsearch.dsl.bean.ElasticSqlParseResult;
  9. import org.elasticsearch.dsl.exception.ElasticSql2DslException;
  10. import org.elasticsearch.dsl.parser.listener.ParseActionListener;
  11. import org.elasticsearch.dsl.parser.listener.ParseActionListenerAdapter;
  12. import org.elasticsearch.dsl.parser.syntax.*;
  13. import org.elasticsearch.sql.ElasticSqlExprParser;
  14. import org.elasticsearch.sql.ElasticSqlSelectQueryBlock;
  15. import java.lang.reflect.Array;
  16. import java.util.Collection;
  17. import java.util.List;
  18. public class ElasticSql2DslParser {
  19. public ElasticSqlParseResult parse(String sql) throws ElasticSql2DslException {
  20. return parse(sql, null, new ParseActionListenerAdapter());
  21. }
  22. public ElasticSqlParseResult parse(String sql, ParseActionListener parseActionListener) throws ElasticSql2DslException {
  23. return parse(sql, null, parseActionListener);
  24. }
  25. public ElasticSqlParseResult parse(String sql, Object[] sqlArgs) throws ElasticSql2DslException {
  26. return parse(sql, sqlArgs, new ParseActionListenerAdapter());
  27. }
  28. public ElasticSqlParseResult parse(String sql, Object[] sqlArgs, ParseActionListener parseActionListener) throws ElasticSql2DslException {
  29. SQLQueryExpr queryExpr = null;
  30. try {
  31. ElasticSqlExprParser elasticSqlExprParser = new ElasticSqlExprParser(sql);
  32. SQLExpr sqlQueryExpr = elasticSqlExprParser.expr();
  33. check(elasticSqlExprParser, sqlQueryExpr, sqlArgs);
  34. queryExpr = (SQLQueryExpr) sqlQueryExpr;
  35. } catch (ParserException ex) {
  36. throw new ElasticSql2DslException(ex);
  37. }
  38. final ElasticDslContext elasticDslContext = new ElasticDslContext(queryExpr, sqlArgs);
  39. if (queryExpr.getSubQuery().getQuery() instanceof ElasticSqlSelectQueryBlock) {
  40. for (QueryParser sqlParser : buildSqlParserChain(parseActionListener)) {
  41. sqlParser.parse(elasticDslContext);
  42. }
  43. } else {
  44. throw new ElasticSql2DslException("[syntax error] Sql only support Select Sql");
  45. }
  46. return elasticDslContext.getParseResult();
  47. }
  48. private void check(ElasticSqlExprParser sqlExprParser, SQLExpr sqlQueryExpr, Object[] sqlArgs) {
  49. if (sqlExprParser.getLexer().token() != Token.EOF) {
  50. throw new ElasticSql2DslException("[syntax error] Sql last token is not EOF");
  51. }
  52. if (!(sqlQueryExpr instanceof SQLQueryExpr)) {
  53. throw new ElasticSql2DslException("[syntax error] Sql is not select sql");
  54. }
  55. if (sqlArgs != null && sqlArgs.length > 0) {
  56. for (Object arg : sqlArgs) {
  57. if (arg instanceof Array || arg instanceof Collection) {
  58. throw new ElasticSql2DslException("[syntax error] Sql arg cannot support collection type");
  59. }
  60. }
  61. }
  62. }
  63. private List<QueryParser> buildSqlParserChain(ParseActionListener parseActionListener) {
  64. //SQL解析器的顺序不能改变
  65. return ImmutableList.of(
  66. //解析SQL指定的索引和文档类型
  67. new QueryFromParser(parseActionListener),
  68. //解析SQL查询指定的match条件
  69. new MatchQueryConditionParser(parseActionListener),
  70. //解析SQL查询指定的where条件
  71. new QueryWhereConditionParser(parseActionListener),
  72. //解析SQL排序条件
  73. new QueryOrderConditionParser(parseActionListener),
  74. //解析路由参数
  75. new QueryRoutingValParser(parseActionListener),
  76. //解析分组统计
  77. new QueryGroupByParser(parseActionListener),
  78. //解析SQL查询指定的字段
  79. new QuerySelectFieldListParser(parseActionListener),
  80. //解析SQL的分页条数
  81. new QueryLimitSizeParser(parseActionListener)
  82. );
  83. }
  84. }