The Ignite community uses the page to keep track of evolution of new Calcite-powered SQL engine. We use the roadmap for better understanding where are we and how close the goal. Please note that the roadmap does not imply any obligations regarding availability and timeline. "Readiness Estimated Time" are subjects to change and represent contributors' best estimate.
At the moment, it seems that it is advisable to split all the work on the new SQL engine into 3 parts.
Please consider Task not a single JIRA task but just a kind of work which could be mapped to many JIRA tickets.
All related tasks should be linked to - IGNITE-12248Getting issue details... STATUS
Task | Contributors | Readiness Estimated Time | Current state |
---|---|---|---|
Support of Indexes | DONE | ||
initial support of DML (SELECT, INSERT) | DONE | ||
Aggregate functions (sum, min, max, avg, ...), enables GROUP BY/DISTINCT commands | DONE | ||
UNION/UNION ALL commands | DONE | ||
support of IN/EXCEPT | DONE | ||
Type system (just review, seems it may be used as-is + write many tests) + support of date/time data types. | DONE |
Task | Contributors | Readiness Estimated Time | Current state |
---|---|---|---|
Schema management | DONE | ||
Sort based aggregates, index spools | DONE | ||
Index Nested Loop Join/Merge Join | DONE | ||
Statistics/cost model (simple statistics) | DONE | ||
Hash index spools/ Hash join | DONE | ||
Initial support of DDL (create/drop for table and index) | DONE | ||
Type system including support of date/time data types. | IN PROGRESS | ||
MERGE | OPEN TO TAKE | ||
Planner hints (ENFORCE JOIN ORDER, Alg of join) | OPEN TO TAKE | ||
Planner hints (the potentially concrete plan of executing) | OPEN TO TAKE | ||
Documentation | OPEN TO TAKE | ||
Task | Contributors | Readiness Estimated Time | Current state |
---|---|---|---|
Statistics/cost model (advanced statistics) | IN PROGRESS | ||
support of DDL (user, grants, ....) | |||
Expressions interpreter | OPEN TO TAKE | ||
Views | OPEN TO TAKE | ||
Tracing, statistics, cancellation, views | OPEN TO TAKE | ||
Memory management and offloading | OPEN TO TAKE | ||
Expressions interpreter (kind of optimization, may be omitted at the first step here a type system is used) | OPEN TO TAKE | ||
Correlated queries support (may be omitted at the first step) | Evgeny Stanilovsky | IN PROGRESS | |
VolcanoPlanner overhaul | OPEN TO TAKE | ||
Distributed joins/aggregation/subqueries algorithms | OPEN TO TAKE | ||
Partition pruning | OPEN TO TAKE | ||
Explain/ExplainAnalyze | OPEN TO TAKE | ||
Query compilation | OPEN TO TAKE | ||
JDBC/ODBC/Thin, other clients (including partition awareness) | OPEN TO TAKE | ||
Documentation | OPEN TO TAKE | ||