Maksim Zhuravkov created IGNITE-21281:
-----------------------------------------
Summary: Sql. Partition pruning. Integrate static partition
pruning into MODIFY statements execution pipeline.
Key: IGNITE-21281
URL: https://issues.apache.org/jira/browse/IGNITE-21281
Project: Ignite
Issue Type: Improvement
Components: sql
Affects Versions: 3.0.0-beta2
Reporter: Maksim Zhuravkov
Given partition pruning information for each scan operator of a QueryPlan, we
can evaluate a partition pruning predicate against statement's execution
context to prune partitions that modify operations won't touch.
1. Traverse fragment tree to analyze inputs of DML operations:
- If Modify operation accepts Scan operation as an input, we do not need to
do anything - since both operations are collocated and this case is coverted by
X).
- For operations that accept Values, we need to consider both Value and
Projection operators, since SQL's VALUES accepts DEFAULT expression.
2. Use affinity function and statement's execution context to evaluate
partition pruning predicates for each scan operator, so enlist is only called
for partitions that should be scanned/modified.
After this issue is resolved, partition pruning should work for INSERT, UPDATE,
MERGE, and DELETE statements.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)