pub struct HashJoinBuffering {}Expand description
Looks for all the HashJoinExecs in the plan and places a BufferExec node with the configured capacity in the probe side:
┌───────────────────┐
│ HashJoinExec │
└─────▲────────▲────┘
┌───────┘ └─────────┐
│ │
┌────────────────┐ ┌─────────────────┐
│ Build side │ + │ BufferExec │
└────────────────┘ └────────▲────────┘
│
┌────────┴────────┐
│ Probe side │
└─────────────────┘Which allows eagerly pulling it even before the build side has completely finished.
Implementations§
Trait Implementations§
Source§impl Debug for HashJoinBuffering
impl Debug for HashJoinBuffering
Source§impl Default for HashJoinBuffering
impl Default for HashJoinBuffering
Source§fn default() -> HashJoinBuffering
fn default() -> HashJoinBuffering
Returns the “default value” for a type. Read more
Source§impl PhysicalOptimizerRule for HashJoinBuffering
impl PhysicalOptimizerRule for HashJoinBuffering
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 form. Read moreSource§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.
Source§fn optimize_with_context(
&self,
plan: Arc<dyn ExecutionPlan>,
context: &dyn PhysicalOptimizerContext,
) -> Result<Arc<dyn ExecutionPlan>>
fn optimize_with_context( &self, plan: Arc<dyn ExecutionPlan>, context: &dyn PhysicalOptimizerContext, ) -> Result<Arc<dyn ExecutionPlan>>
Rewrite
plan with access to extended context (statistics registry, etc.). Read moreAuto Trait Implementations§
impl Freeze for HashJoinBuffering
impl RefUnwindSafe for HashJoinBuffering
impl Send for HashJoinBuffering
impl Sync for HashJoinBuffering
impl Unpin for HashJoinBuffering
impl UnsafeUnpin for HashJoinBuffering
impl UnwindSafe for HashJoinBuffering
Blanket Implementations§
impl<T> Allocation for T
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