gpt4 book ai didi

java - Apache 方解石 : Convert a SQL parse tree into a tree of relational expressions WITHOUT validation

转载 作者:行者123 更新时间:2023-11-30 07:01:40 25 4
gpt4 key购买 nike

我目前正在开发一个项目,我想在其中解析 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直接,我收到错误,我必须首先验证查询。这就是我面临麻烦的地方。我没有有效的架构。我只想将查询转换为关系查询计划。有没有办法跳过验证过程?

最佳答案

无法跳过验证过程。 SQL 到关系型转换器依赖于 validator 之前创建的状态。

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

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

关于java - Apache 方解石 : Convert a SQL parse tree into a tree of relational expressions WITHOUT validation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40804289/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com