pub struct JoinSelection {}
Expand description
The JoinSelection
rule tries to modify a given plan so that it can
accommodate infinite sources and optimize joins in the plan according to
available statistical information, if there is any.
Implementations§
Source§impl JoinSelection
impl JoinSelection
Trait Implementations§
Source§impl Debug for JoinSelection
impl Debug for JoinSelection
Source§impl Default for JoinSelection
impl Default for JoinSelection
Source§fn default() -> JoinSelection
fn default() -> JoinSelection
Returns the “default value” for a type. Read more
Source§impl PhysicalOptimizerRule for JoinSelection
impl PhysicalOptimizerRule for JoinSelection
Source§fn optimize(
&self,
plan: Arc<dyn ExecutionPlan>,
config: &ConfigOptions,
) -> Result<Arc<dyn ExecutionPlan>>
fn optimize( &self, plan: Arc<dyn ExecutionPlan>, config: &ConfigOptions, ) -> Result<Arc<dyn ExecutionPlan>>
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 valid 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 JoinSelection
impl RefUnwindSafe for JoinSelection
impl Send for JoinSelection
impl Sync for JoinSelection
impl Unpin for JoinSelection
impl UnwindSafe for JoinSelection
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> 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