В настоящее время я работаю над проектом, в котором я хочу проанализировать 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);
Если я попытаюсь выполнить rel-метод Планировщика напрямую, я получаю сообщение об ошибке, что сначала нужно проверить запрос. И тут я сталкиваюсь с проблемами. У меня нет действительной схемы. Я просто хочу преобразовать запрос в реляционный план запроса. Есть ли способ пропустить процесс проверки?