| 1 | #include "duckdb/optimizer/rule/ordered_aggregate_optimizer.hpp" | 
|---|---|
| 2 | |
| 3 | #include "duckdb/optimizer/matcher/expression_matcher.hpp" | 
| 4 | #include "duckdb/planner/expression/bound_aggregate_expression.hpp" | 
| 5 | |
| 6 | namespace duckdb { | 
| 7 | |
| 8 | OrderedAggregateOptimizer::OrderedAggregateOptimizer(ExpressionRewriter &rewriter) : Rule(rewriter) { | 
| 9 | // we match on an OR expression within a LogicalFilter node | 
| 10 | root = make_uniq<ExpressionMatcher>(); | 
| 11 | root->expr_class = ExpressionClass::BOUND_AGGREGATE; | 
| 12 | } | 
| 13 | |
| 14 | unique_ptr<Expression> OrderedAggregateOptimizer::Apply(LogicalOperator &op, vector<reference<Expression>> &bindings, | 
| 15 | bool &changes_made, bool is_root) { | 
| 16 | auto &aggr = bindings[0].get().Cast<BoundAggregateExpression>(); | 
| 17 | if (!aggr.order_bys) { | 
| 18 | // no ORDER BYs defined | 
| 19 | return nullptr; | 
| 20 | } | 
| 21 | if (aggr.function.order_dependent == AggregateOrderDependent::NOT_ORDER_DEPENDENT) { | 
| 22 | // not an order dependent aggregate but we have an ORDER BY clause - remove it | 
| 23 | aggr.order_bys.reset(); | 
| 24 | changes_made = true; | 
| 25 | return nullptr; | 
| 26 | } | 
| 27 | return nullptr; | 
| 28 | } | 
| 29 | |
| 30 | } // namespace duckdb | 
| 31 |