pub struct TopKAggregation {}Expand description
An optimizer rule that passes a limit hint to aggregations if the whole result is not needed
Implementations§
Source§impl TopKAggregation
impl TopKAggregation
Sourcepub fn new() -> TopKAggregation
pub fn new() -> TopKAggregation
Create a new LimitAggregation
Trait Implementations§
Source§impl Debug for TopKAggregation
impl Debug for TopKAggregation
Source§impl Default for TopKAggregation
impl Default for TopKAggregation
Source§fn default() -> TopKAggregation
fn default() -> TopKAggregation
Returns the “default value” for a type. Read more
Source§impl PhysicalOptimizerRule for TopKAggregation
impl PhysicalOptimizerRule for TopKAggregation
Source§fn optimize(
&self,
plan: Arc<dyn ExecutionPlan>,
config: &ConfigOptions,
) -> Result<Arc<dyn ExecutionPlan>, DataFusionError>
fn optimize( &self, plan: Arc<dyn ExecutionPlan>, config: &ConfigOptions, ) -> Result<Arc<dyn ExecutionPlan>, DataFusionError>
Rewrite
plan to an optimized formSource§fn schema_check(&self) -> bool
fn schema_check(&self) -> bool
A flag to indicate whether the physical planner should validate that the rule will not
change the schema of the plan after the rewriting.
Some of the optimization rules might change the nullable properties of the schema
and should disable the schema check.
Auto Trait Implementations§
impl Freeze for TopKAggregation
impl RefUnwindSafe for TopKAggregation
impl Send for TopKAggregation
impl Sync for TopKAggregation
impl Unpin for TopKAggregation
impl UnwindSafe for TopKAggregation
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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