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-12248 - Getting issue details... STATUS

Phase 1: Simple SQL are work

TaskContributorsReadiness Estimated TimeCurrent 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

Phase 2: Base performance optimization and extend SQL possibilities

TaskContributorsReadiness Estimated TimeCurrent 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












Phase 3: Usability and performance

TaskContributorsReadiness Estimated TimeCurrent state
Statistics/cost model (advanced statistics)

IN PROGRESS

support of DDL (user, grants, ....)


OPEN TO TAKE
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



















  • No labels