Skip to main content

HashJoinOperator

Struct HashJoinOperator 

Source
pub struct HashJoinOperator { /* private fields */ }
Expand description

Hash join operator.

Builds a hash table from the build side (right) and probes with the probe side (left). Efficient for equality joins on one or more columns.

Implementations§

Source§

impl HashJoinOperator

Source

pub fn new( probe_side: Box<dyn Operator>, build_side: Box<dyn Operator>, probe_keys: Vec<usize>, build_keys: Vec<usize>, join_type: JoinType, output_schema: Vec<LogicalType>, ) -> Self

Creates a new hash join operator.

§Arguments
  • probe_side - Left side operator (will be probed).
  • build_side - Right side operator (will build hash table).
  • probe_keys - Column indices on probe side for join keys.
  • build_keys - Column indices on build side for join keys.
  • join_type - Type of join to perform.
  • output_schema - Schema of the output (probe columns + build columns).

Trait Implementations§

Source§

impl Operator for HashJoinOperator

Source§

fn next(&mut self) -> OperatorResult

Returns the next chunk of data, or None if exhausted.
Source§

fn reset(&mut self)

Resets the operator to its initial state.
Source§

fn name(&self) -> &'static str

Returns the name of this operator for debugging.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.