Skip to content

Commit

Permalink
refactor: cleanup AggregateFunctionPlanner
Browse files Browse the repository at this point in the history
  • Loading branch information
tshauck committed Jul 7, 2024
1 parent 07bee49 commit 6782364
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 303 deletions.
80 changes: 61 additions & 19 deletions datafusion/functions-aggregate/src/aggregate_function_planner.rs
Original file line number Diff line number Diff line change
@@ -1,38 +1,80 @@
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

use datafusion_expr::{
expr, lit,
planner::{PlannerResult, RawAggregateFunction, UserDefinedSQLPlanner},
utils::COUNT_STAR_EXPANSION,
Expr,
};

fn is_wildcard(expr: &Expr) -> bool {
matches!(expr, Expr::Wildcard { qualifier: None })
}

pub struct AggregateFunctionPlanner;

impl UserDefinedSQLPlanner for AggregateFunctionPlanner {
fn plan_aggregate_function(
impl AggregateFunctionPlanner {
fn plan_count(
&self,
aggregate_function: RawAggregateFunction,
) -> datafusion_common::Result<PlannerResult<RawAggregateFunction>> {
let RawAggregateFunction {
udf,
args,
distinct,
filter,
order_by,
null_treatment,
} = aggregate_function.clone();

if udf.name() == "count" && args.is_empty() {
if aggregate_function.args.is_empty() {
return Ok(PlannerResult::Planned(Expr::AggregateFunction(
expr::AggregateFunction::new_udf(
aggregate_function.udf,
vec![lit(COUNT_STAR_EXPANSION).alias("count()")],
aggregate_function.distinct,
aggregate_function.filter,
aggregate_function.order_by,
aggregate_function.null_treatment,
),
)));
}

if aggregate_function.udf.name() == "count"
&& aggregate_function.args.len() == 1
&& is_wildcard(&aggregate_function.args[0])
{
return Ok(PlannerResult::Planned(Expr::AggregateFunction(
expr::AggregateFunction::new_udf(
udf.clone(),
vec![lit(1).alias("")],
distinct,
filter.clone(),
order_by.clone(),
null_treatment.clone(),
aggregate_function.udf,
vec![lit(COUNT_STAR_EXPANSION).alias("*")],
aggregate_function.distinct,
aggregate_function.filter,
aggregate_function.order_by,
aggregate_function.null_treatment,
),
)));
}

Ok(PlannerResult::Original(aggregate_function.clone()))
Ok(PlannerResult::Original(aggregate_function))
}
}

impl UserDefinedSQLPlanner for AggregateFunctionPlanner {
fn plan_aggregate_function(
&self,
aggregate_function: RawAggregateFunction,
) -> datafusion_common::Result<PlannerResult<RawAggregateFunction>> {
if aggregate_function.udf.name() == "count" {
return self.plan_count(aggregate_function);
}

Ok(PlannerResult::Original(aggregate_function))
}
}
280 changes: 0 additions & 280 deletions datafusion/optimizer/src/analyzer/count_wildcard_rule.rs

This file was deleted.

Loading

0 comments on commit 6782364

Please sign in to comment.