mirror of
https://github.com/GreptimeTeam/greptimedb.git
synced 2026-01-06 21:32:58 +00:00
* basic impl Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * fix frontend logic Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * add sqlness test Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * check substrait compatibility before pushdown Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * going to revert some rules Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * update sqlness result Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * fix test and clippy Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * fix compile error Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * fix typo Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * remove println Signed-off-by: Ruihang Xia <waynestxia@gmail.com> * Apply suggestions from code review Co-authored-by: Yingwen <realevenyag@gmail.com> --------- Signed-off-by: Ruihang Xia <waynestxia@gmail.com> Co-authored-by: Yingwen <realevenyag@gmail.com>
68 lines
3.6 KiB
Plaintext
68 lines
3.6 KiB
Plaintext
explain select * from numbers;
|
|
|
|
+---------------+------------------------------------------+
|
|
| plan_type | plan |
|
|
+---------------+------------------------------------------+
|
|
| logical_plan | MergeScan [is_placeholder=false] |
|
|
| | TableScan: numbers projection=[number] |
|
|
| physical_plan | ExecutionPlan(PlaceHolder) |
|
|
| | |
|
|
+---------------+------------------------------------------+
|
|
|
|
explain select * from numbers order by number desc;
|
|
|
|
+---------------+--------------------------------------------+
|
|
| plan_type | plan |
|
|
+---------------+--------------------------------------------+
|
|
| logical_plan | Sort: numbers.number DESC NULLS FIRST |
|
|
| | MergeScan [is_placeholder=false] |
|
|
| | TableScan: numbers projection=[number] |
|
|
| physical_plan | SortExec: expr=[number@0 DESC] |
|
|
| | ExecutionPlan(PlaceHolder) |
|
|
| | |
|
|
+---------------+--------------------------------------------+
|
|
|
|
explain select * from numbers order by number asc;
|
|
|
|
+---------------+--------------------------------------------+
|
|
| plan_type | plan |
|
|
+---------------+--------------------------------------------+
|
|
| logical_plan | Sort: numbers.number ASC NULLS LAST |
|
|
| | MergeScan [is_placeholder=false] |
|
|
| | TableScan: numbers projection=[number] |
|
|
| physical_plan | SortExec: expr=[number@0 ASC NULLS LAST] |
|
|
| | ExecutionPlan(PlaceHolder) |
|
|
| | |
|
|
+---------------+--------------------------------------------+
|
|
|
|
explain select * from numbers order by number desc limit 10;
|
|
|
|
+---------------+---------------------------------------------------+
|
|
| plan_type | plan |
|
|
+---------------+---------------------------------------------------+
|
|
| logical_plan | Limit: skip=0, fetch=10 |
|
|
| | Sort: numbers.number DESC NULLS FIRST, fetch=10 |
|
|
| | MergeScan [is_placeholder=false] |
|
|
| | TableScan: numbers projection=[number] |
|
|
| physical_plan | GlobalLimitExec: skip=0, fetch=10 |
|
|
| | SortExec: fetch=10, expr=[number@0 DESC] |
|
|
| | ExecutionPlan(PlaceHolder) |
|
|
| | |
|
|
+---------------+---------------------------------------------------+
|
|
|
|
explain select * from numbers order by number asc limit 10;
|
|
|
|
+---------------+------------------------------------------------------+
|
|
| plan_type | plan |
|
|
+---------------+------------------------------------------------------+
|
|
| logical_plan | Limit: skip=0, fetch=10 |
|
|
| | Sort: numbers.number ASC NULLS LAST, fetch=10 |
|
|
| | MergeScan [is_placeholder=false] |
|
|
| | TableScan: numbers projection=[number] |
|
|
| physical_plan | GlobalLimitExec: skip=0, fetch=10 |
|
|
| | SortExec: fetch=10, expr=[number@0 ASC NULLS LAST] |
|
|
| | ExecutionPlan(PlaceHolder) |
|
|
| | |
|
|
+---------------+------------------------------------------------------+
|
|
|