pub struct AggregateFunctionExpr { /* private fields */ }
Expand description
Physical aggregate expression of a UDAF.
Implementations§
source§impl AggregateFunctionExpr
impl AggregateFunctionExpr
sourcepub fn fun(&self) -> &AggregateUDF
pub fn fun(&self) -> &AggregateUDF
Return the AggregateUDF
used by this AggregateFunctionExpr
sourcepub fn is_distinct(&self) -> bool
pub fn is_distinct(&self) -> bool
Return if the aggregation is distinct
sourcepub fn ignore_nulls(&self) -> bool
pub fn ignore_nulls(&self) -> bool
Return if the aggregation ignores nulls
sourcepub fn is_reversed(&self) -> bool
pub fn is_reversed(&self) -> bool
Return if the aggregation is reversed
Trait Implementations§
source§impl AggregateExpr for AggregateFunctionExpr
impl AggregateExpr for AggregateFunctionExpr
source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Return a reference to Any that can be used for downcasting
source§fn expressions(&self) -> Vec<Arc<dyn PhysicalExpr>>
fn expressions(&self) -> Vec<Arc<dyn PhysicalExpr>>
expressions that are passed to the Accumulator.
Single-column aggregations such as
sum
return a single value, others (e.g. cov
) return many.source§fn state_fields(&self) -> Result<Vec<Field>, DataFusionError>
fn state_fields(&self) -> Result<Vec<Field>, DataFusionError>
the fields that encapsulate the Accumulator’s state
the number of fields here equals the number of states that the accumulator contains
source§fn field(&self) -> Result<Field, DataFusionError>
fn field(&self) -> Result<Field, DataFusionError>
the field of the final result of this aggregation.
source§fn create_accumulator(&self) -> Result<Box<dyn Accumulator>, DataFusionError>
fn create_accumulator(&self) -> Result<Box<dyn Accumulator>, DataFusionError>
the accumulator used to accumulate values from the expressions.
the accumulator expects the same number of arguments as
expressions
and must
return states with the same description as state_fields
source§fn create_sliding_accumulator(
&self,
) -> Result<Box<dyn Accumulator>, DataFusionError>
fn create_sliding_accumulator( &self, ) -> Result<Box<dyn Accumulator>, DataFusionError>
Creates accumulator implementation that supports retract
source§fn name(&self) -> &str
fn name(&self) -> &str
Human readable name such as
"MIN(c2)"
. The default
implementation returns placeholder text.source§fn groups_accumulator_supported(&self) -> bool
fn groups_accumulator_supported(&self) -> bool
If the aggregate expression has a specialized
GroupsAccumulator
implementation. If this returns true,
[Self::create_groups_accumulator
] will be called.source§fn create_groups_accumulator(
&self,
) -> Result<Box<dyn GroupsAccumulator>, DataFusionError>
fn create_groups_accumulator( &self, ) -> Result<Box<dyn GroupsAccumulator>, DataFusionError>
Return a specialized
GroupsAccumulator
that manages state
for all groups. Read moresource§fn order_bys(&self) -> Option<&[PhysicalSortExpr]>
fn order_bys(&self) -> Option<&[PhysicalSortExpr]>
Order by requirements for the aggregate function
By default it is
None
(there is no requirement)
Order-sensitive aggregators, such as FIRST_VALUE(x ORDER BY y)
should implement thissource§fn order_sensitivity(&self) -> AggregateOrderSensitivity
fn order_sensitivity(&self) -> AggregateOrderSensitivity
Indicates whether aggregator can produce the correct result with any
arbitrary input ordering. By default, we assume that aggregate expressions
are order insensitive.
source§fn with_beneficial_ordering(
self: Arc<AggregateFunctionExpr>,
beneficial_ordering: bool,
) -> Result<Option<Arc<dyn AggregateExpr>>, DataFusionError>
fn with_beneficial_ordering( self: Arc<AggregateFunctionExpr>, beneficial_ordering: bool, ) -> Result<Option<Arc<dyn AggregateExpr>>, DataFusionError>
Sets the indicator whether ordering requirements of the aggregator is
satisfied by its input. If this is not the case, aggregators with order
sensitivity
AggregateOrderSensitivity::Beneficial
can still produce
the correct result with possibly more work internally. Read moresource§fn reverse_expr(&self) -> Option<Arc<dyn AggregateExpr>>
fn reverse_expr(&self) -> Option<Arc<dyn AggregateExpr>>
Construct an expression that calculates the aggregate in reverse.
Typically the “reverse” expression is itself (e.g. SUM, COUNT).
For aggregates that do not support calculation in reverse,
returns None (which is the default value).
source§fn get_minmax_desc(&self) -> Option<(Field, bool)>
fn get_minmax_desc(&self) -> Option<(Field, bool)>
If this function is max, return (output_field, true)
if the function is min, return (output_field, false)
otherwise return None (the default) Read more
source§fn all_expressions(&self) -> AggregatePhysicalExpressions
fn all_expressions(&self) -> AggregatePhysicalExpressions
Returns all expressions used in the
AggregateExpr
.
These expressions are (1)function arguments, (2) order by expressions.source§fn with_new_expressions(
&self,
_args: Vec<Arc<dyn PhysicalExpr>>,
_order_by_exprs: Vec<Arc<dyn PhysicalExpr>>,
) -> Option<Arc<dyn AggregateExpr>>
fn with_new_expressions( &self, _args: Vec<Arc<dyn PhysicalExpr>>, _order_by_exprs: Vec<Arc<dyn PhysicalExpr>>, ) -> Option<Arc<dyn AggregateExpr>>
Rewrites
AggregateExpr
, with new expressions given. The argument should be consistent
with the return value of the AggregateExpr::all_expressions
method.
Returns Some(Arc<dyn AggregateExpr>)
if re-write is supported, otherwise returns None
.
TODO: This method only rewrites the PhysicalExpr
s and does not handle Expr
s.
This can cause silent bugs and should be fixed in the future (possibly with physical-to-logical
conversions).source§impl Clone for AggregateFunctionExpr
impl Clone for AggregateFunctionExpr
source§fn clone(&self) -> AggregateFunctionExpr
fn clone(&self) -> AggregateFunctionExpr
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for AggregateFunctionExpr
impl Debug for AggregateFunctionExpr
source§impl PartialEq<dyn Any> for AggregateFunctionExpr
impl PartialEq<dyn Any> for AggregateFunctionExpr
Auto Trait Implementations§
impl Freeze for AggregateFunctionExpr
impl !RefUnwindSafe for AggregateFunctionExpr
impl Send for AggregateFunctionExpr
impl Sync for AggregateFunctionExpr
impl Unpin for AggregateFunctionExpr
impl !UnwindSafe for AggregateFunctionExpr
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more