2

我目前正在做一个项目,我想在其中解析一个 SQL 查询并为其创建关系表达式树。主要目标是识别查询中的加入伙伴。所以我想将连接表达式向下推到树的叶子上。为此,我决定使用 Apache Calcite。我的代码目前大致是这样的:

Planner planner = Frameworks.getPlanner(Frameworks.newConfigBuilder().defaultSchema(Frameworks.createRootSchema(false)).build());

SqlNode parsed = planner.parse("SELECT s.dnasamplename, e.Total_expression_level, e.Soluble_expression_level, s.id " +
            "FROM table1 e" +
            "JOIN table2 s on s.constructname = e.Clone_name" +
            "WHERE e.Total_expression_level like '0:%'");

planner.validate(parsed);

RelRoot relRoot = planner.rel(parsed);

如果我尝试直接执行Planner的 rel-Method ,我会收到必须先验证查询的错误。这就是我面临麻烦的地方。我没有有效的架构。我只想将查询转换为关系查询计划。有没有办法跳过验证过程?

4

1 回答 1

3

无法跳过验证过程。sql-to-relational 转换器依赖于先前由验证器创建的状态。

人们看到如果 SQL 无效,验证器会抛出异常,并认为这是它的唯一目的;但建设国家同样重要。状态包括每个 SqlNode 类型的映射、SELECT 子句中“*”和“tableAlias.*”的扩展以及完全限定的标识符。

如果您的架构丢失或不完整,您可以尝试与 Apache Drill 类似的方法。如果验证器询问表的特定列,而该表没有该列,则该表的 Calcite 命名空间会显示“是的,我有该列!” 并添加它。因此,验证过程成功,并且每个命名空间都有一个查询所需的额外列的列表。

于 2016-11-26T00:08:37.923 回答